@whitesev/pops 2.0.5 → 2.0.7

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.
Files changed (57) hide show
  1. package/dist/index.amd.js +134 -80
  2. package/dist/index.amd.js.map +1 -1
  3. package/dist/index.cjs.js +134 -80
  4. package/dist/index.cjs.js.map +1 -1
  5. package/dist/index.esm.js +134 -80
  6. package/dist/index.esm.js.map +1 -1
  7. package/dist/index.iife.js +134 -80
  8. package/dist/index.iife.js.map +1 -1
  9. package/dist/index.system.js +134 -80
  10. package/dist/index.system.js.map +1 -1
  11. package/dist/index.umd.js +134 -80
  12. package/dist/index.umd.js.map +1 -1
  13. package/dist/types/src/Pops.d.ts +20411 -15
  14. package/dist/types/src/components/alert/index.d.ts +3 -3
  15. package/dist/types/src/components/confirm/index.d.ts +3 -3
  16. package/dist/types/src/components/drawer/index.d.ts +3 -3
  17. package/dist/types/src/components/drawer/indexType.d.ts +10 -2
  18. package/dist/types/src/components/folder/index.d.ts +3 -3
  19. package/dist/types/src/components/folder/indexType.d.ts +4 -1
  20. package/dist/types/src/components/iframe/index.d.ts +6 -3
  21. package/dist/types/src/components/iframe/indexType.d.ts +2 -0
  22. package/dist/types/src/components/loading/index.d.ts +3 -3
  23. package/dist/types/src/components/loading/indexType.d.ts +10 -1
  24. package/dist/types/src/components/panel/index.d.ts +3 -3
  25. package/dist/types/src/components/panel/indexType.d.ts +1 -0
  26. package/dist/types/src/components/panel/sliderType.d.ts +14 -4
  27. package/dist/types/src/components/prompt/index.d.ts +3 -3
  28. package/dist/types/src/components/prompt/indexType.d.ts +1 -0
  29. package/dist/types/src/components/rightClickMenu/index.d.ts +20315 -3
  30. package/dist/types/src/components/rightClickMenu/indexType.d.ts +6 -2
  31. package/dist/types/src/components/searchSuggestion/index.d.ts +141 -3
  32. package/dist/types/src/components/searchSuggestion/indexType.d.ts +0 -108
  33. package/dist/types/src/components/tooltip/index.d.ts +51 -3
  34. package/package.json +1 -1
  35. package/src/Pops.ts +25 -24
  36. package/src/components/alert/index.ts +6 -5
  37. package/src/components/confirm/index.ts +6 -5
  38. package/src/components/drawer/index.ts +6 -5
  39. package/src/components/drawer/indexType.ts +10 -2
  40. package/src/components/folder/index.ts +6 -5
  41. package/src/components/folder/indexType.ts +4 -1
  42. package/src/components/iframe/index.ts +4 -4
  43. package/src/components/iframe/indexType.ts +2 -0
  44. package/src/components/loading/config.ts +1 -1
  45. package/src/components/loading/index.ts +12 -11
  46. package/src/components/loading/indexType.ts +10 -1
  47. package/src/components/panel/PanelHandleContentDetails.ts +62 -29
  48. package/src/components/panel/index.ts +6 -5
  49. package/src/components/panel/indexType.ts +1 -0
  50. package/src/components/panel/sliderType.ts +14 -4
  51. package/src/components/prompt/index.ts +6 -5
  52. package/src/components/prompt/indexType.ts +1 -0
  53. package/src/components/rightClickMenu/index.ts +4 -5
  54. package/src/components/rightClickMenu/indexType.ts +6 -7
  55. package/src/components/searchSuggestion/index.ts +4 -4
  56. package/src/components/searchSuggestion/indexType.ts +0 -109
  57. package/src/components/tooltip/index.ts +9 -9
@@ -3247,8 +3247,8 @@ var pops = (function () {
3247
3247
  };
3248
3248
  };
3249
3249
 
3250
- class PopsAlert {
3251
- constructor(details) {
3250
+ const PopsAlert = {
3251
+ init(details) {
3252
3252
  const guid = popsUtils.getRandomGUID();
3253
3253
  // 设置当前类型
3254
3254
  const PopsType = "alert";
@@ -3337,9 +3337,10 @@ var pops = (function () {
3337
3337
  endCallBack: config.dragEndCallBack,
3338
3338
  });
3339
3339
  }
3340
- return PopsHandler.handleResultDetails(eventDetails);
3341
- }
3342
- }
3340
+ let result = PopsHandler.handleResultDetails(eventDetails);
3341
+ return result;
3342
+ },
3343
+ };
3343
3344
 
3344
3345
  const PopsConfirmConfig = () => {
3345
3346
  return {
@@ -3429,8 +3430,8 @@ var pops = (function () {
3429
3430
  };
3430
3431
  };
3431
3432
 
3432
- class PopsConfirm {
3433
- constructor(details) {
3433
+ const PopsConfirm = {
3434
+ init(details) {
3434
3435
  const guid = popsUtils.getRandomGUID();
3435
3436
  // 设置当前类型
3436
3437
  const PopsType = "confirm";
@@ -3520,9 +3521,10 @@ var pops = (function () {
3520
3521
  endCallBack: config.dragEndCallBack,
3521
3522
  });
3522
3523
  }
3523
- return PopsHandler.handleResultDetails(eventDetails);
3524
- }
3525
- }
3524
+ let result = PopsHandler.handleResultDetails(eventDetails);
3525
+ return result;
3526
+ },
3527
+ };
3526
3528
 
3527
3529
  const PopsPromptConfig = () => {
3528
3530
  return {
@@ -3616,8 +3618,8 @@ var pops = (function () {
3616
3618
  };
3617
3619
  };
3618
3620
 
3619
- class PopsPrompt {
3620
- constructor(details) {
3621
+ const PopsPrompt = {
3622
+ init(details) {
3621
3623
  const guid = popsUtils.getRandomGUID();
3622
3624
  // 设置当前类型
3623
3625
  const PopsType = "prompt";
@@ -3723,9 +3725,10 @@ var pops = (function () {
3723
3725
  if (config.content.select) {
3724
3726
  $input.select();
3725
3727
  }
3726
- return PopsHandler.handleResultDetails(eventDetails);
3727
- }
3728
- }
3728
+ let result = PopsHandler.handleResultDetails(eventDetails);
3729
+ return result;
3730
+ },
3731
+ };
3729
3732
 
3730
3733
  const PopsLoadingConfig = () => {
3731
3734
  return {
@@ -3749,13 +3752,14 @@ var pops = (function () {
3749
3752
  },
3750
3753
  animation: "pops-anim-fadein-zoom",
3751
3754
  forbiddenScroll: false,
3755
+ isAbsolute: false,
3752
3756
  style: null,
3753
3757
  addIndexCSS: true,
3754
3758
  };
3755
3759
  };
3756
3760
 
3757
- class PopsLoading {
3758
- constructor(details) {
3761
+ const PopsLoading = {
3762
+ init(details) {
3759
3763
  let config = PopsLoadingConfig();
3760
3764
  config = popsUtils.assign(config, GlobalConfig.getGlobalConfig());
3761
3765
  config = popsUtils.assign(config, details);
@@ -3785,9 +3789,6 @@ var pops = (function () {
3785
3789
  * 弹窗的主元素,包括动画层
3786
3790
  */
3787
3791
  let $anim = PopsElementHandler.parseElement(animHTML);
3788
- // 遮罩层必须是跟随主内容
3789
- // 即设置主内容position: relative,mask:position: absolute
3790
- popsDOMUtils.css($anim, "position", "absolute !important");
3791
3792
  let { popsElement: $pops } = PopsHandler.handleQueryElement($anim, PopsType);
3792
3793
  /**
3793
3794
  * 遮罩层元素
@@ -3807,9 +3808,6 @@ var pops = (function () {
3807
3808
  maskHTML: maskHTML,
3808
3809
  });
3809
3810
  $mask = _handleMask_.maskElement;
3810
- // 遮罩层必须是跟随主内容
3811
- // 即设置主内容position: relative,mask:position: absolute
3812
- popsDOMUtils.css($mask, "position", "absolute !important");
3813
3811
  elementList.push($mask);
3814
3812
  }
3815
3813
  let eventDetails = PopsHandler.handleLoadingEventDetails(guid, PopsType, $anim, $pops, $mask, config);
@@ -3823,9 +3821,16 @@ var pops = (function () {
3823
3821
  popsElement: $pops,
3824
3822
  maskElement: $mask,
3825
3823
  });
3826
- return PopsHandler.handleResultDetails(eventDetails);
3827
- }
3828
- }
3824
+ if (config.isAbsolute) {
3825
+ // 遮罩层必须是跟随主内容
3826
+ // 即设置主内容position: relative,mask:position: absolute
3827
+ popsDOMUtils.css($anim, "position", "absolute !important");
3828
+ $mask && popsDOMUtils.css($mask, "position", "absolute !important");
3829
+ }
3830
+ let result = PopsHandler.handleResultDetails(eventDetails);
3831
+ return result;
3832
+ },
3833
+ };
3829
3834
 
3830
3835
  const PopsIframeConfig = () => {
3831
3836
  return {
@@ -3885,8 +3890,8 @@ var pops = (function () {
3885
3890
  };
3886
3891
  };
3887
3892
 
3888
- class PopsIframe {
3889
- constructor(details) {
3893
+ const PopsIframe = {
3894
+ init(details) {
3890
3895
  const guid = popsUtils.getRandomGUID();
3891
3896
  // 设置当前类型
3892
3897
  const PopsType = "iframe";
@@ -4116,8 +4121,8 @@ var pops = (function () {
4116
4121
  });
4117
4122
  let result = PopsHandler.handleResultDetails(eventDetails);
4118
4123
  return result;
4119
- }
4120
- }
4124
+ },
4125
+ };
4121
4126
 
4122
4127
  const PopsDrawerConfig = () => {
4123
4128
  return {
@@ -4206,8 +4211,8 @@ var pops = (function () {
4206
4211
  };
4207
4212
  };
4208
4213
 
4209
- class PopsDrawer {
4210
- constructor(details) {
4214
+ const PopsDrawer = {
4215
+ init(details) {
4211
4216
  const guid = popsUtils.getRandomGUID();
4212
4217
  // 设置当前类型
4213
4218
  const PopsType = "drawer";
@@ -4368,9 +4373,10 @@ var pops = (function () {
4368
4373
  $shadowContainer: $shadowContainer,
4369
4374
  $shadowRoot: $shadowRoot,
4370
4375
  });
4371
- return PopsHandler.handleResultDetails(eventDetails);
4372
- }
4373
- }
4376
+ let result = PopsHandler.handleResultDetails(eventDetails);
4377
+ return result;
4378
+ },
4379
+ };
4374
4380
 
4375
4381
  const PopsFolderConfig = () => {
4376
4382
  return {
@@ -4532,8 +4538,8 @@ var pops = (function () {
4532
4538
  dwg: "",
4533
4539
  };
4534
4540
 
4535
- class PopsFolder {
4536
- constructor(details) {
4541
+ const PopsFolder = {
4542
+ init(details) {
4537
4543
  const guid = popsUtils.getRandomGUID();
4538
4544
  // 设置当前类型
4539
4545
  const PopsType = "folder";
@@ -5315,9 +5321,10 @@ var pops = (function () {
5315
5321
  $shadowContainer: $shadowContainer,
5316
5322
  $shadowRoot: $shadowRoot,
5317
5323
  });
5318
- return PopsHandler.handleResultDetails(eventDetails);
5319
- }
5320
- }
5324
+ let result = PopsHandler.handleResultDetails(eventDetails);
5325
+ return result;
5326
+ },
5327
+ };
5321
5328
 
5322
5329
  const PopsPanelConfig = () => {
5323
5330
  return {
@@ -6200,6 +6207,7 @@ var pops = (function () {
6200
6207
  */
6201
6208
  createSectionContainerItem_slider_new(formConfig) {
6202
6209
  let liElement = document.createElement("li");
6210
+ // @ts-ignore
6203
6211
  liElement["__formConfig__"] = formConfig;
6204
6212
  this.setElementClassName(liElement, formConfig.className);
6205
6213
  this.setElementAttributes(liElement, formConfig.attributes);
@@ -6300,15 +6308,15 @@ var pops = (function () {
6300
6308
  this.setPanEvent();
6301
6309
  this.setRunAwayClickEvent();
6302
6310
  this.intervalInit();
6303
- if (formConfig.disabled) {
6311
+ if (this.isFormConfigDisabledDrag()) {
6304
6312
  this.disableDrag();
6305
6313
  }
6306
6314
  },
6307
6315
  /**
6308
6316
  * 10s内循环获取slider的宽度等信息
6309
6317
  * 获取到了就可以初始化left的值
6310
- * @param {number} [checkStepTime=200] 每次检测的间隔时间
6311
- * @param {number} [maxTime=10000] 最大的检测时间
6318
+ * @param [checkStepTime=200] 每次检测的间隔时间
6319
+ * @param [maxTime=10000] 最大的检测时间
6312
6320
  */
6313
6321
  intervalInit(checkStepTime = 200, maxTime = 10000) {
6314
6322
  if (this.$interval.isCheck) {
@@ -6354,9 +6362,13 @@ var pops = (function () {
6354
6362
  this.$ele.slider.setAttribute("data-max", this.max.toString());
6355
6363
  this.$ele.slider.setAttribute("data-value", this.value.toString());
6356
6364
  this.$ele.slider.setAttribute("data-step", this.step.toString());
6365
+ // @ts-ignore
6357
6366
  this.$ele.slider["data-min"] = this.min;
6367
+ // @ts-ignore
6358
6368
  this.$ele.slider["data-max"] = this.max;
6369
+ // @ts-ignore
6359
6370
  this.$ele.slider["data-value"] = this.value;
6371
+ // @ts-ignore
6360
6372
  this.$ele.slider["data-step"] = this.step;
6361
6373
  },
6362
6374
  /**
@@ -6471,7 +6483,6 @@ var pops = (function () {
6471
6483
  /**
6472
6484
  * 判断数字是否是浮点数
6473
6485
  * @param num
6474
- * @returns
6475
6486
  */
6476
6487
  isFloat(num) {
6477
6488
  return Number(num) === num && num % 1 !== 0;
@@ -6488,6 +6499,7 @@ var pops = (function () {
6488
6499
  },
6489
6500
  /**
6490
6501
  * 根据拖拽距离获取滑块应该在的区间和值
6502
+ * @param dragX
6491
6503
  */
6492
6504
  getDragInfo(dragX) {
6493
6505
  let result = this.$data.stepBlockMap.get(0);
@@ -6502,7 +6514,7 @@ var pops = (function () {
6502
6514
  },
6503
6515
  /**
6504
6516
  * 获取滑块的当前脱拖拽占据的百分比
6505
- * @param {number} dragWidth
6517
+ * @param dragWidth
6506
6518
  */
6507
6519
  getSliderPositonPercent(dragWidth) {
6508
6520
  return dragWidth / this.$data.totalWidth;
@@ -6554,6 +6566,21 @@ var pops = (function () {
6554
6566
  isDisabledDrag() {
6555
6567
  return this.$ele.runAway.classList.contains("pops-slider-is-disabled");
6556
6568
  },
6569
+ /**
6570
+ * 判断当前滑块是否被禁用(配置中判断)
6571
+ */
6572
+ isFormConfigDisabledDrag() {
6573
+ if (typeof formConfig.disabled === "function" ||
6574
+ typeof formConfig.disabled === "boolean") {
6575
+ let isDisabled = typeof formConfig.disabled === "function"
6576
+ ? formConfig.disabled()
6577
+ : formConfig.disabled;
6578
+ return isDisabled;
6579
+ }
6580
+ else {
6581
+ return false;
6582
+ }
6583
+ },
6557
6584
  /**
6558
6585
  * 设置进度条点击定位的事件
6559
6586
  */
@@ -6576,9 +6603,17 @@ var pops = (function () {
6576
6603
  */
6577
6604
  dragStartCallBack() {
6578
6605
  if (!this.$data.isMove) {
6579
- if (this.isDisabledDrag()) {
6606
+ if (this.isFormConfigDisabledDrag()) {
6607
+ // 禁止
6608
+ this.disableDrag();
6580
6609
  return false;
6581
6610
  }
6611
+ else {
6612
+ // 允许
6613
+ if (this.isDisabledDrag()) {
6614
+ this.allowDrag();
6615
+ }
6616
+ }
6582
6617
  this.$data.isMove = true;
6583
6618
  }
6584
6619
  return true;
@@ -6725,6 +6760,14 @@ var pops = (function () {
6725
6760
  passive: true,
6726
6761
  },
6727
6762
  showBeforeCallBack: () => {
6763
+ let isShowHoverTip = typeof formConfig.isShowHoverTip === "function"
6764
+ ? formConfig.isShowHoverTip()
6765
+ : typeof formConfig.isShowHoverTip === "boolean"
6766
+ ? formConfig.isShowHoverTip
6767
+ : true;
6768
+ if (!isShowHoverTip) {
6769
+ return false;
6770
+ }
6728
6771
  this.intervalInit();
6729
6772
  },
6730
6773
  showAfterCallBack: (toolTipNode) => {
@@ -8309,8 +8352,8 @@ var pops = (function () {
8309
8352
  };
8310
8353
  };
8311
8354
 
8312
- class PopsPanel {
8313
- constructor(details) {
8355
+ const PopsPanel = {
8356
+ init(details) {
8314
8357
  const guid = popsUtils.getRandomGUID();
8315
8358
  // 设置当前类型
8316
8359
  const PopsType = "panel";
@@ -8423,9 +8466,10 @@ var pops = (function () {
8423
8466
  endCallBack: config.dragEndCallBack,
8424
8467
  });
8425
8468
  }
8426
- return PopsHandler.handleResultDetails(eventDetails);
8427
- }
8428
- }
8469
+ let result = PopsHandler.handleResultDetails(eventDetails);
8470
+ return result;
8471
+ },
8472
+ };
8429
8473
 
8430
8474
  const rightClickMenuConfig = () => {
8431
8475
  return {
@@ -8552,8 +8596,8 @@ var pops = (function () {
8552
8596
  };
8553
8597
  };
8554
8598
 
8555
- class PopsRightClickMenu {
8556
- constructor(details) {
8599
+ const PopsRightClickMenu = {
8600
+ init(details) {
8557
8601
  const guid = popsUtils.getRandomGUID();
8558
8602
  // 设置当前类型
8559
8603
  const PopsType = "rightClickMenu";
@@ -8979,8 +9023,8 @@ var pops = (function () {
8979
9023
  removeContextMenuEvent: PopsContextMenu.removeContextMenuEvent,
8980
9024
  addContextMenuEvent: PopsContextMenu.addContextMenuEvent,
8981
9025
  };
8982
- }
8983
- }
9026
+ },
9027
+ };
8984
9028
 
8985
9029
  const searchSuggestionConfig = () => {
8986
9030
  return {
@@ -9039,8 +9083,8 @@ var pops = (function () {
9039
9083
  };
9040
9084
  };
9041
9085
 
9042
- class PopsSearchSuggestion {
9043
- constructor(details) {
9086
+ const PopsSearchSuggestion = {
9087
+ init(details) {
9044
9088
  const guid = popsUtils.getRandomGUID();
9045
9089
  // 设置当前类型
9046
9090
  const PopsType = "searchSuggestion";
@@ -9578,8 +9622,8 @@ var pops = (function () {
9578
9622
  },
9579
9623
  };
9580
9624
  return SearchSuggestion;
9581
- }
9582
- }
9625
+ },
9626
+ };
9583
9627
 
9584
9628
  const PopsTooltipConfig = () => {
9585
9629
  // @ts-ignore
@@ -10042,8 +10086,8 @@ var pops = (function () {
10042
10086
  popsDOMUtils.off(this.$el.$toolTip, "mouseleave touchend", this.toolTipMouseLeaveEvent, this.$data.config.eventOption);
10043
10087
  }
10044
10088
  }
10045
- class PopsTooltip {
10046
- constructor(details) {
10089
+ const PopsTooltip = {
10090
+ init(details) {
10047
10091
  const guid = popsUtils.getRandomGUID();
10048
10092
  // 设置当前类型
10049
10093
  const PopsType = "tooltip";
@@ -10071,20 +10115,20 @@ var pops = (function () {
10071
10115
  toolTip.show();
10072
10116
  }
10073
10117
  return {
10074
- guid: guid,
10075
- config: config,
10076
- $shadowContainer: $shadowContainer,
10077
- $shadowRoot: $shadowRoot,
10078
- toolTip: toolTip,
10118
+ guid,
10119
+ config,
10120
+ $shadowContainer,
10121
+ $shadowRoot,
10122
+ toolTip,
10079
10123
  };
10080
- }
10081
- }
10124
+ },
10125
+ };
10082
10126
 
10083
10127
  class Pops {
10084
10128
  /** 配置 */
10085
10129
  config = {
10086
10130
  /** 版本号 */
10087
- version: "2025.5.12",
10131
+ version: "2025.5.25",
10088
10132
  cssText: {
10089
10133
  /** 主CSS */
10090
10134
  index: indexCSS,
@@ -10230,42 +10274,47 @@ var pops = (function () {
10230
10274
  * @param details 配置
10231
10275
  */
10232
10276
  alert = (details) => {
10233
- return new PopsAlert(details);
10277
+ let dialog = PopsAlert.init(details);
10278
+ return dialog;
10234
10279
  };
10235
10280
  /**
10236
10281
  * 询问框
10237
10282
  * @param details 配置
10238
10283
  */
10239
10284
  confirm = (details) => {
10240
- return new PopsConfirm(details);
10285
+ let dialog = PopsConfirm.init(details);
10286
+ return dialog;
10241
10287
  };
10242
10288
  /**
10243
10289
  * 输入框
10244
10290
  * @param details 配置
10245
10291
  */
10246
10292
  prompt = (details) => {
10247
- return new PopsPrompt(details);
10293
+ let dialog = PopsPrompt.init(details);
10294
+ return dialog;
10248
10295
  };
10249
10296
  /**
10250
10297
  * 加载层
10251
10298
  * @param details 配置
10252
10299
  */
10253
10300
  loading = (details) => {
10254
- return new PopsLoading(details);
10301
+ let popsLoading = PopsLoading.init(details);
10302
+ return popsLoading;
10255
10303
  };
10256
10304
  /**
10257
10305
  * iframe层
10258
10306
  * @param details 配置
10259
10307
  */
10260
10308
  iframe = (details) => {
10261
- return new PopsIframe(details);
10309
+ let dialog = PopsIframe.init(details);
10310
+ return dialog;
10262
10311
  };
10263
10312
  /**
10264
10313
  * 提示框
10265
10314
  * @param details 配置
10266
10315
  */
10267
10316
  tooltip = (details) => {
10268
- let popsTooltip = new PopsTooltip(details);
10317
+ let popsTooltip = PopsTooltip.init(details);
10269
10318
  return popsTooltip;
10270
10319
  };
10271
10320
  /**
@@ -10273,35 +10322,40 @@ var pops = (function () {
10273
10322
  * @param details 配置
10274
10323
  */
10275
10324
  drawer = (details) => {
10276
- return new PopsDrawer(details);
10325
+ let dialog = PopsDrawer.init(details);
10326
+ return dialog;
10277
10327
  };
10278
10328
  /**
10279
10329
  * 文件夹
10280
10330
  * @param details 配置
10281
10331
  */
10282
10332
  folder = (details) => {
10283
- return new PopsFolder(details);
10333
+ let dialog = PopsFolder.init(details);
10334
+ return dialog;
10284
10335
  };
10285
10336
  /**
10286
10337
  * 配置面板
10287
10338
  * @param details 配置
10288
10339
  */
10289
10340
  panel = (details) => {
10290
- return new PopsPanel(details);
10341
+ let dialog = PopsPanel.init(details);
10342
+ return dialog;
10291
10343
  };
10292
10344
  /**
10293
10345
  * 右键菜单
10294
10346
  * @param details 配置
10295
10347
  */
10296
10348
  rightClickMenu = (details) => {
10297
- return new PopsRightClickMenu(details);
10349
+ let popsRightClickMenu = PopsRightClickMenu.init(details);
10350
+ return popsRightClickMenu;
10298
10351
  };
10299
10352
  /**
10300
10353
  * 搜索建议
10301
10354
  * @param details 配置
10302
10355
  */
10303
10356
  searchSuggestion = (details) => {
10304
- return new PopsSearchSuggestion(details);
10357
+ let popsSearchSuggestion = PopsSearchSuggestion.init(details);
10358
+ return popsSearchSuggestion;
10305
10359
  };
10306
10360
  }
10307
10361
  const pops = new Pops();