@deskhero/dh_ui 1.59.1 → 1.59.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.
package/dist/dh_ui.es.js CHANGED
@@ -1,4 +1,4 @@
1
- import { reactive, ref, defineComponent, useSlots, toRef, provide, computed, onMounted, onUnmounted, watch, openBlock, createElementBlock, normalizeClass, unref, createVNode, mergeProps, isRef, createSlots, renderList, withCtx, renderSlot, normalizeProps, guardReactiveProps, createBlock, Teleport, createCommentVNode, inject, withKeys, withModifiers, Transition, createElementVNode, Fragment, normalizeStyle, createTextVNode, toDisplayString, resolveDynamicComponent, nextTick, withDirectives, vShow, onBeforeUpdate, getCurrentScope, onScopeDispose, vModelCheckbox, shallowRef, onBeforeUnmount, toRaw, h, isProxy, resolveComponent, pushScopeId, popScopeId, vModelText, useCssVars, toRefs, getCurrentInstance, vModelDynamic, onUpdated } from "vue";
1
+ import { reactive, ref, defineComponent, useSlots, toRef, provide, computed, onMounted, onUnmounted, watch, openBlock, createElementBlock, normalizeClass, unref, createVNode, mergeProps, isRef, createSlots, renderList, withCtx, renderSlot, normalizeProps, guardReactiveProps, createBlock, Teleport, createCommentVNode, inject, withKeys, withModifiers, Transition, createElementVNode, Fragment, normalizeStyle, createTextVNode, toDisplayString, resolveDynamicComponent, nextTick, withDirectives, vShow, onBeforeUpdate, getCurrentScope, onScopeDispose, vModelCheckbox, shallowRef, onBeforeUnmount, toRaw, h, isProxy, resolveComponent, pushScopeId, popScopeId, vModelText, useCssVars, onBeforeMount, toRefs, getCurrentInstance, vModelDynamic, onUpdated } from "vue";
2
2
  var main$1 = "";
3
3
  function toInteger(dirtyNumber) {
4
4
  if (dirtyNumber === null || dirtyNumber === true || dirtyNumber === false) {
@@ -10741,7 +10741,7 @@ var __glob_1_60 = "
10741
10741
  var __glob_1_61 = "";
10742
10742
  var __glob_1_62 = "";
10743
10743
  var __glob_1_63 = "";
10744
- var __glob_1_64 = "";
10744
+ var __glob_1_64 = "";
10745
10745
  var __glob_1_65 = "";
10746
10746
  var __glob_1_66 = "";
10747
10747
  var __glob_1_67 = "";
@@ -24468,6 +24468,30 @@ const _hoisted_17$1 = /* @__PURE__ */ createElementVNode("button", { class: "fil
24468
24468
  const _sfc_main$e = {
24469
24469
  __name: "FileUpload",
24470
24470
  props: {
24471
+ fileList: {
24472
+ type: Array,
24473
+ required: false,
24474
+ default: () => {
24475
+ return [];
24476
+ }
24477
+ },
24478
+ fileFormats: {
24479
+ type: Array,
24480
+ required: false,
24481
+ default: () => {
24482
+ return [
24483
+ ".pdf",
24484
+ ".csv",
24485
+ ".doc",
24486
+ ".jpeg",
24487
+ ".jpg",
24488
+ ".mp4",
24489
+ ".png",
24490
+ ".txt",
24491
+ ".xls"
24492
+ ];
24493
+ }
24494
+ },
24471
24495
  uploadProgress: {
24472
24496
  type: Array,
24473
24497
  required: true
@@ -24618,7 +24642,10 @@ const _sfc_main$e = {
24618
24642
  }
24619
24643
  }
24620
24644
  function saveFile() {
24621
- emit("save:modelValue", files.value);
24645
+ if (files.value.length) {
24646
+ console.log(files.value);
24647
+ emit("save:modelValue", files.value);
24648
+ }
24622
24649
  }
24623
24650
  function generateLink(file) {
24624
24651
  return URL.createObjectURL(file);
@@ -24627,6 +24654,13 @@ const _sfc_main$e = {
24627
24654
  e2.preventDefault();
24628
24655
  emit("reload");
24629
24656
  }
24657
+ onBeforeMount(() => {
24658
+ if (props.fileList.length) {
24659
+ files.value = props.fileList;
24660
+ fileSelected.value = true;
24661
+ saveFile();
24662
+ }
24663
+ });
24630
24664
  return (_ctx, _cache) => {
24631
24665
  return openBlock(), createElementBlock("div", {
24632
24666
  class: normalizeClass(["file__upload", {
@@ -43316,9 +43350,10 @@ class ImageTool {
43316
43350
  this.wrapper = document.createElement("div");
43317
43351
  this.wrapper.classList.add("picture__upload_btn");
43318
43352
  this.fileInput = document.createElement("input");
43319
- this.fileInput.id = "upload_pdf";
43353
+ const uniqueId = `upload_image_${Date.now()}`;
43354
+ this.fileInput.id = uniqueId;
43320
43355
  this.fileInput.type = "file";
43321
- this.fileInput.name = "file";
43356
+ this.fileInput.name = "image";
43322
43357
  this.fileInput.accept = "image/*";
43323
43358
  this.icon = document.createElement("IMG");
43324
43359
  this.icon.classList.add("picture__upload_btn_icon");
@@ -43328,7 +43363,7 @@ class ImageTool {
43328
43363
  };
43329
43364
  this.icon.height = "24";
43330
43365
  this.label = document.createElement("label");
43331
- this.label.setAttribute("for", "upload_pdf");
43366
+ this.label.setAttribute("for", uniqueId);
43332
43367
  this.label.textContent = "Drag & drop image file or ";
43333
43368
  this.browse = document.createElement("span");
43334
43369
  this.browse.textContent = "browse";
@@ -43448,21 +43483,14 @@ class FileTool {
43448
43483
  }
43449
43484
  constructor({ data, config, api }) {
43450
43485
  this.data = {
43451
- fileLink: data.fileLink || "",
43452
- fileId: data.fileId !== void 0 ? data.fileId : 0,
43453
- width: data.width !== void 0 ? data.width : "WidthFull",
43454
- position: data.position !== void 0 ? data.position : "AlignCenter"
43486
+ fileLinks: data.fileLinks || [],
43487
+ fileIds: data.fileIds || []
43455
43488
  };
43456
43489
  this.api = api;
43457
43490
  this.config = config || {};
43458
43491
  this.wrapper = null;
43459
43492
  this.fileInput = null;
43460
- this.result = null;
43461
- this.name = null;
43462
- this.img = null;
43463
- this.label = null;
43464
- this.icon = null;
43465
- this.browse = null;
43493
+ this.resultContainer = null;
43466
43494
  this.uploading = false;
43467
43495
  }
43468
43496
  render() {
@@ -43471,7 +43499,8 @@ class FileTool {
43471
43499
  this.wrapper = document.createElement("div");
43472
43500
  this.wrapper.classList.add("picture__upload_btn");
43473
43501
  this.fileInput = document.createElement("input");
43474
- this.fileInput.id = "upload_pdf";
43502
+ const uniqueId = `upload_file_${Date.now()}`;
43503
+ this.fileInput.id = uniqueId;
43475
43504
  this.fileInput.type = "file";
43476
43505
  this.fileInput.name = "file";
43477
43506
  this.fileInput.multiple = true;
@@ -43483,7 +43512,7 @@ class FileTool {
43483
43512
  };
43484
43513
  this.icon.height = "24";
43485
43514
  this.label = document.createElement("label");
43486
- this.label.setAttribute("for", "upload_pdf");
43515
+ this.label.setAttribute("for", uniqueId);
43487
43516
  this.label.textContent = "Drag & drop file(s) or ";
43488
43517
  this.browse = document.createElement("span");
43489
43518
  this.browse.textContent = "browse";
@@ -43492,22 +43521,18 @@ class FileTool {
43492
43521
  this.wrapper.prepend(this.icon);
43493
43522
  this.wrapper.appendChild(this.label);
43494
43523
  this.wrapper.appendChild(this.fileInput);
43495
- this.result = document.createElement("div");
43496
- this.result.classList.add("file__result");
43497
- this.img = document.createElement("IMG");
43498
- this.img.classList.add("file__result_icon");
43499
- this.img.src = FileIcon;
43500
- this.name = document.createElement("a");
43501
- this.name.classList.add("file__result_name");
43502
- this.result.style.display = "none";
43503
- this.result.appendChild(this.img);
43504
- this.result.appendChild(this.name);
43524
+ this.resultContainer = document.createElement("div");
43525
+ this.resultContainer.classList.add("file__results");
43526
+ this.resultContainer.style.gap = "7px";
43527
+ if (!this.data.fileIds.length) {
43528
+ this.resultContainer.style.display = "none";
43529
+ }
43505
43530
  this.container.appendChild(this.wrapper);
43506
- this.container.appendChild(this.result);
43507
- if (this.data && this.data.fileLink) {
43508
- this.name.href = this.data.fileLink;
43509
- this.result.style.display = "flex";
43531
+ this.container.appendChild(this.resultContainer);
43532
+ this.populateExistingFiles();
43533
+ if (this.data && this.data.fileIds.length) {
43510
43534
  this.wrapper.style.display = "none";
43535
+ this.resultContainer.style.display = "flex";
43511
43536
  }
43512
43537
  if (this.api.readOnly.isEnabled) {
43513
43538
  this._acceptTuneView();
@@ -43518,44 +43543,80 @@ class FileTool {
43518
43543
  });
43519
43544
  this.wrapper.addEventListener("drop", (e2) => {
43520
43545
  e2.preventDefault();
43521
- const file = e2.dataTransfer.files[0];
43522
- this.handleFile(file);
43546
+ const files = Array.from(e2.dataTransfer.files);
43547
+ this.handleFiles(files);
43523
43548
  });
43524
43549
  this.fileInput.addEventListener("input", (e2) => {
43525
43550
  e2.stopPropagation();
43526
- const file = this.fileInput.files[0];
43527
- this.handleFile(file);
43551
+ const files = Array.from(this.fileInput.files);
43552
+ this.handleFiles(files);
43528
43553
  });
43529
43554
  return this.container;
43530
43555
  }
43531
- handleFile(file) {
43532
- if (file !== void 0) {
43556
+ populateExistingFiles() {
43557
+ for (let i2 = 0; i2 < this.data.fileLinks.length; i2++) {
43558
+ const fileLink = this.data.fileLinks[i2];
43559
+ const fileId = this.data.fileIds[i2];
43560
+ const result = this.createResultElement(fileLink, fileId);
43561
+ this.resultContainer.appendChild(result);
43562
+ }
43563
+ }
43564
+ createResultElement(fileLink, fileId) {
43565
+ const result = document.createElement("div");
43566
+ result.classList.add("file__result");
43567
+ const img = document.createElement("IMG");
43568
+ img.classList.add("file__result_icon");
43569
+ img.src = FileIcon;
43570
+ const name = document.createElement("a");
43571
+ name.classList.add("file__result_name");
43572
+ name.href = fileLink;
43573
+ name.innerHTML = fileId.toString();
43574
+ name.download = fileId.toString();
43575
+ result.appendChild(img);
43576
+ result.appendChild(name);
43577
+ return result;
43578
+ }
43579
+ handleFiles(files) {
43580
+ if (files.length > 0) {
43533
43581
  this.wrapper.style.display = "none";
43534
- const url = URL.createObjectURL(file);
43535
- this.name.href = url;
43536
- this.name.innerHTML = file.name;
43537
- this.name.download = file.name;
43538
- this.result.style.display = "flex";
43582
+ this.resultContainer.style.display = "flex";
43583
+ for (const file of files) {
43584
+ const url = URL.createObjectURL(file);
43585
+ const fileId = this.generateFileId();
43586
+ const result = this.createResultElement(url, fileId);
43587
+ this.resultContainer.appendChild(result);
43588
+ this.uploadFile(file, fileId);
43589
+ }
43539
43590
  this.uploading = true;
43540
- this.uploadFile(file);
43541
43591
  } else {
43542
43592
  alert("Invalid file type. Please select a valid file.");
43543
43593
  }
43544
43594
  }
43595
+ generateFileId() {
43596
+ return Math.floor(Math.random() * 1e6);
43597
+ }
43545
43598
  save(blockContent) {
43546
- const file = blockContent.querySelector(".file__result");
43547
- if (!file) {
43599
+ const files = blockContent.querySelectorAll(".file__result");
43600
+ if (files.length === 0) {
43548
43601
  return this.data;
43549
43602
  }
43603
+ const fileLinks = [];
43604
+ const fileIds = [];
43605
+ for (const file of files) {
43606
+ const name = file.querySelector(".file__result_name");
43607
+ fileLinks.push(name.href);
43608
+ fileIds.push(name.innerHTML);
43609
+ }
43550
43610
  return Object.assign(this.data, {
43551
- fileLink: this.data.fileLink,
43552
- fileId: this.data.fileId
43611
+ fileLinks,
43612
+ fileIds
43553
43613
  });
43554
43614
  }
43555
- uploadFile(file) {
43615
+ uploadFile(file, fileId) {
43556
43616
  const uploadFile = new CustomEvent("uploadFile", {
43557
43617
  detail: {
43558
- file
43618
+ file,
43619
+ fileId
43559
43620
  }
43560
43621
  });
43561
43622
  document.dispatchEvent(uploadFile);
@@ -43694,14 +43755,18 @@ const _sfc_main$2 = {
43694
43755
  return words.value > 300 ? true : false;
43695
43756
  });
43696
43757
  expose({
43697
- editorJS,
43698
43758
  toggleReadOnly,
43699
43759
  save,
43700
43760
  reset: reset2,
43701
43761
  editBlock
43702
43762
  });
43703
43763
  function toggleReadOnly() {
43704
- editorJS.value.readOnly.toggle();
43764
+ if (editorJS.value.configuration.data.blocks.length) {
43765
+ console.log(editorJS.value.configuration.data.blocks);
43766
+ editorJS.value.readOnly.toggle();
43767
+ } else {
43768
+ alert("You must at least have one block to toggle preview");
43769
+ }
43705
43770
  }
43706
43771
  function save() {
43707
43772
  return editorJS.value.save();