minimal-piral 0.15.0-beta.4630 → 0.15.0-beta.4670

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.
@@ -2715,8 +2715,8 @@ var ForeignComponentContainer = /*#__PURE__*/function (_React$Component) {
2715
2715
  key: "render",
2716
2716
  value: function render() {
2717
2717
  var $portalId = this.props.$portalId;
2718
- return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", {
2719
- "data-portal-id": $portalId,
2718
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("piral-portal", {
2719
+ pid: $portalId,
2720
2720
  ref: this.setNode
2721
2721
  });
2722
2722
  }
@@ -4070,6 +4070,16 @@ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.g
4070
4070
 
4071
4071
 
4072
4072
  if (typeof window !== 'undefined' && 'customElements' in window) {
4073
+ /**
4074
+ * This is a nice abstraction allowing anyone to actually use the extension system
4075
+ * brought by Piral. Not all props of the extension system are actually exposed.
4076
+ *
4077
+ * Usage:
4078
+ *
4079
+ * ```
4080
+ * <piral-extension name="my-ext-name"></piral-extension>
4081
+ * ```
4082
+ */
4073
4083
  var PiralExtension = /*#__PURE__*/function (_HTMLElement) {
4074
4084
  _inherits(PiralExtension, _HTMLElement);
4075
4085
 
@@ -4122,6 +4132,8 @@ if (typeof window !== 'undefined' && 'customElements' in window) {
4122
4132
  }, {
4123
4133
  key: "connectedCallback",
4124
4134
  value: function connectedCallback() {
4135
+ this.style.display = 'contents';
4136
+
4125
4137
  if (this.isConnected) {
4126
4138
  this.dispatchEvent(new CustomEvent('render-html', {
4127
4139
  bubbles: true,
@@ -4162,7 +4174,74 @@ if (typeof window !== 'undefined' && 'customElements' in window) {
4162
4174
  return PiralExtension;
4163
4175
  }( /*#__PURE__*/_wrapNativeSuper(HTMLElement));
4164
4176
 
4165
- customElements.define('piral-extension', PiralExtension);
4177
+ customElements.define(_utils__WEBPACK_IMPORTED_MODULE_2__.extensionName, PiralExtension);
4178
+ /**
4179
+ * This is a boundary to host elements from other frameworks - effectively vanishing
4180
+ * at runtime.
4181
+ *
4182
+ * Usage:
4183
+ *
4184
+ * ```
4185
+ * <piral-portal pid="host-1234"></piral-portal>
4186
+ * ```
4187
+ */
4188
+
4189
+ var PiralPortal = /*#__PURE__*/function (_HTMLElement2) {
4190
+ _inherits(PiralPortal, _HTMLElement2);
4191
+
4192
+ var _super2 = _createSuper(PiralPortal);
4193
+
4194
+ function PiralPortal() {
4195
+ _classCallCheck(this, PiralPortal);
4196
+
4197
+ return _super2.apply(this, arguments);
4198
+ }
4199
+
4200
+ _createClass(PiralPortal, [{
4201
+ key: "connectedCallback",
4202
+ value: function connectedCallback() {
4203
+ this.style.display = 'contents';
4204
+ }
4205
+ }]);
4206
+
4207
+ return PiralPortal;
4208
+ }( /*#__PURE__*/_wrapNativeSuper(HTMLElement));
4209
+
4210
+ customElements.define(_utils__WEBPACK_IMPORTED_MODULE_2__.portalName, PiralPortal);
4211
+ /**
4212
+ * This is a virtual element to aggregate rendering from other frameworks, mostly
4213
+ * used like piral-portal, but without context-hosting capabilities. This would
4214
+ * be used exclusively within a foreign framework, not from Piral to initiate.
4215
+ *
4216
+ * Usage:
4217
+ *
4218
+ * ```
4219
+ * <piral-slot></piral-slot>
4220
+ * ```
4221
+ */
4222
+
4223
+ var PiralSlot = /*#__PURE__*/function (_HTMLElement3) {
4224
+ _inherits(PiralSlot, _HTMLElement3);
4225
+
4226
+ var _super3 = _createSuper(PiralSlot);
4227
+
4228
+ function PiralSlot() {
4229
+ _classCallCheck(this, PiralSlot);
4230
+
4231
+ return _super3.apply(this, arguments);
4232
+ }
4233
+
4234
+ _createClass(PiralSlot, [{
4235
+ key: "connectedCallback",
4236
+ value: function connectedCallback() {
4237
+ this.style.display = 'contents';
4238
+ }
4239
+ }]);
4240
+
4241
+ return PiralSlot;
4242
+ }( /*#__PURE__*/_wrapNativeSuper(HTMLElement));
4243
+
4244
+ customElements.define(_utils__WEBPACK_IMPORTED_MODULE_2__.slotName, PiralSlot);
4166
4245
  }
4167
4246
 
4168
4247
  function renderElement(context, element, props) {
@@ -4547,7 +4626,7 @@ var SlotCarrier = function SlotCarrier(_ref) {
4547
4626
  }, [nodes]);
4548
4627
 
4549
4628
  if (nodes.length) {
4550
- return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("slot", {
4629
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("piral-slot", {
4551
4630
  ref: host
4552
4631
  });
4553
4632
  }
@@ -4596,13 +4675,19 @@ __webpack_require__.r(__webpack_exports__);
4596
4675
  /* harmony export */ "attachDomPortal": () => (/* binding */ attachDomPortal),
4597
4676
  /* harmony export */ "changeDomPortal": () => (/* binding */ changeDomPortal),
4598
4677
  /* harmony export */ "convertComponent": () => (/* binding */ convertComponent),
4599
- /* harmony export */ "renderInDom": () => (/* binding */ renderInDom)
4678
+ /* harmony export */ "extensionName": () => (/* binding */ extensionName),
4679
+ /* harmony export */ "portalName": () => (/* binding */ portalName),
4680
+ /* harmony export */ "renderInDom": () => (/* binding */ renderInDom),
4681
+ /* harmony export */ "slotName": () => (/* binding */ slotName)
4600
4682
  /* harmony export */ });
4601
4683
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "../../../node_modules/react/index.js");
4602
4684
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
4603
4685
  /* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-dom */ "../../../node_modules/react-dom/index.js");
4604
4686
 
4605
4687
 
4688
+ var extensionName = 'piral-extension';
4689
+ var portalName = 'piral-portal';
4690
+ var slotName = 'piral-slot';
4606
4691
  function attachDomPortal(id, context, element, component, props) {
4607
4692
  var portal = /*#__PURE__*/(0,react_dom__WEBPACK_IMPORTED_MODULE_1__.createPortal)( /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.createElement)(component, props), element);
4608
4693
  context.showPortal(id, portal);
@@ -4621,11 +4706,11 @@ function convertComponent(converter, component) {
4621
4706
  return converter(component);
4622
4707
  }
4623
4708
  function renderInDom(context, element, component, props) {
4624
- var portalId = 'data-portal-id';
4709
+ var portalId = 'pid';
4625
4710
  var parent = element;
4626
4711
 
4627
4712
  while (parent) {
4628
- if (parent instanceof Element && parent.hasAttribute(portalId)) {
4713
+ if (parent instanceof Element && parent.localName === portalName && parent.hasAttribute(portalId)) {
4629
4714
  var id = parent.getAttribute(portalId);
4630
4715
  return attachDomPortal(id, context, element, component, props);
4631
4716
  }
@@ -5363,7 +5448,7 @@ function installPiralDebug(options) {
5363
5448
  type: 'boolean',
5364
5449
  label: 'State container logging',
5365
5450
  onChange: function onChange(value) {
5366
- setValue('dbg:view-state', value ? 'on' : 'off');
5451
+ setValue(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.viewState, value ? 'on' : 'off');
5367
5452
  }
5368
5453
  },
5369
5454
  loadPilets: {
@@ -5371,7 +5456,7 @@ function installPiralDebug(options) {
5371
5456
  type: 'boolean',
5372
5457
  label: 'Load available pilets',
5373
5458
  onChange: function onChange(value) {
5374
- setValue('dbg:load-pilets', value ? 'on' : 'off');
5459
+ setValue(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.loadPilets, value ? 'on' : 'off');
5375
5460
  }
5376
5461
  },
5377
5462
  hardRefresh: {
@@ -5379,7 +5464,7 @@ function installPiralDebug(options) {
5379
5464
  type: 'boolean',
5380
5465
  label: 'Full refresh on change',
5381
5466
  onChange: function onChange(value) {
5382
- setValue('dbg:hard-refresh', value ? 'on' : 'off');
5467
+ setValue(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.hardRefresh, value ? 'on' : 'off');
5383
5468
  }
5384
5469
  },
5385
5470
  viewOrigins: {
@@ -5387,7 +5472,7 @@ function installPiralDebug(options) {
5387
5472
  type: 'boolean',
5388
5473
  label: 'Visualize component origins',
5389
5474
  onChange: function onChange(value, prev) {
5390
- setValue('dbg:view-origins', value ? 'on' : 'off');
5475
+ setValue(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.viewOrigins, value ? 'on' : 'off');
5391
5476
 
5392
5477
  if (prev !== value) {
5393
5478
  updateVisualize(value);
@@ -5399,7 +5484,7 @@ function installPiralDebug(options) {
5399
5484
  type: 'boolean',
5400
5485
  label: 'Enable extension catalogue',
5401
5486
  onChange: function onChange(value) {
5402
- setValue('dbg:extension-catalogue', value ? 'on' : 'off');
5487
+ setValue(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.extensionCatalogue, value ? 'on' : 'off');
5403
5488
  }
5404
5489
  },
5405
5490
  clearConsole: {
@@ -5407,7 +5492,7 @@ function installPiralDebug(options) {
5407
5492
  type: 'boolean',
5408
5493
  label: 'Clear console during HMR',
5409
5494
  onChange: function onChange(value) {
5410
- setValue('dbg:clear-console', value ? 'on' : 'off');
5495
+ setValue(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.clearConsole, value ? 'on' : 'off');
5411
5496
  }
5412
5497
  },
5413
5498
  persistSettings: {
@@ -5582,12 +5667,12 @@ function installPiralDebug(options) {
5582
5667
  debug: debugApiVersion,
5583
5668
  instance: {
5584
5669
  name: "minimal-piral",
5585
- version: "0.15.0-beta.4630",
5670
+ version: "0.15.0-beta.4670",
5586
5671
  dependencies: "tslib,react,react-dom,react-router,react-router-dom"
5587
5672
  },
5588
5673
  build: {
5589
- date: "2022-08-29T23:57:37.325Z",
5590
- cli: "0.14.30",
5674
+ date: "2022-09-20T22:33:46.464Z",
5675
+ cli: "0.14.31",
5591
5676
  compat: "0.14"
5592
5677
  }
5593
5678
  };
@@ -5715,11 +5800,12 @@ function installPiralDebug(options) {
5715
5800
  if (!legacyBrowser && event.storageArea === sessionStorage) {
5716
5801
  // potentially unknowingly updated settings
5717
5802
  updateSettings({
5718
- viewState: sessionStorage.getItem('dbg:view-state') !== 'off',
5719
- loadPilets: sessionStorage.getItem('dbg:load-pilets') === 'on',
5720
- hardRefresh: sessionStorage.getItem('dbg:hard-refresh') === 'on',
5721
- viewOrigins: sessionStorage.getItem('dbg:view-origins') === 'on',
5722
- extensionCatalogue: sessionStorage.getItem('dbg:extension-catalogue') !== 'off'
5803
+ viewState: sessionStorage.getItem(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.viewState) !== 'off',
5804
+ loadPilets: sessionStorage.getItem(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.loadPilets) === 'on',
5805
+ hardRefresh: sessionStorage.getItem(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.hardRefresh) === 'on',
5806
+ viewOrigins: sessionStorage.getItem(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.viewOrigins) === 'on',
5807
+ extensionCatalogue: sessionStorage.getItem(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.extensionCatalogue) !== 'off',
5808
+ clearConsole: sessionStorage.getItem(_state__WEBPACK_IMPORTED_MODULE_0__.settingsKeys.clearConsole) === 'on'
5723
5809
  });
5724
5810
  }
5725
5811
  });
@@ -6044,6 +6130,7 @@ __webpack_require__.r(__webpack_exports__);
6044
6130
  /* harmony export */ "navigate": () => (/* binding */ navigate),
6045
6131
  /* harmony export */ "setNavigate": () => (/* binding */ setNavigate),
6046
6132
  /* harmony export */ "setState": () => (/* binding */ setState),
6133
+ /* harmony export */ "settingsKeys": () => (/* binding */ settingsKeys),
6047
6134
  /* harmony export */ "subscribe": () => (/* binding */ subscribe),
6048
6135
  /* harmony export */ "useDebugState": () => (/* binding */ useDebugState)
6049
6136
  /* harmony export */ });
@@ -6062,7 +6149,16 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy
6062
6149
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
6063
6150
 
6064
6151
 
6065
- var persistKey = 'dbg:persist-settings-data';
6152
+ var settingsKeys = {
6153
+ viewState: 'dbg:view-state',
6154
+ loadPilets: 'dbg:load-pilets',
6155
+ hardRefresh: 'dbg:hard-refresh',
6156
+ viewOrigins: 'dbg:view-origins',
6157
+ extensionCatalogue: 'dbg:extension-catalogue',
6158
+ clearConsole: 'dbg:clear-console',
6159
+ persistSettings: 'dbg:persist-settings-data'
6160
+ };
6161
+ var persistKey = settingsKeys.persistSettings;
6066
6162
  var persistSettings = !!localStorage.getItem(persistKey);
6067
6163
 
6068
6164
  var defaultSetter = function defaultSetter(name, value) {
@@ -6091,11 +6187,17 @@ if (persistSettings) {
6091
6187
 
6092
6188
  function enablePersistance() {
6093
6189
  var data = {};
6190
+ var validKeys = Object.keys(settingsKeys).map(function (m) {
6191
+ return settingsKeys[m];
6192
+ });
6094
6193
 
6095
6194
  for (var i = 0; i < sessionStorage.length; i++) {
6096
6195
  var name = sessionStorage.key(i);
6097
- var value = sessionStorage.getItem(name);
6098
- data[name] = value;
6196
+
6197
+ if (validKeys.includes(name)) {
6198
+ var value = sessionStorage.getItem(name);
6199
+ data[name] = value;
6200
+ }
6099
6201
  }
6100
6202
 
6101
6203
  localStorage.setItem(persistKey, JSON.stringify(data));
@@ -6107,12 +6209,12 @@ function disablePersistance() {
6107
6209
  }
6108
6210
  var initialSetter = persistSettings ? persistentSetter : defaultSetter;
6109
6211
  var initialSettings = {
6110
- viewState: sessionStorage.getItem('dbg:view-state') !== 'off',
6111
- loadPilets: sessionStorage.getItem('dbg:load-pilets') === 'on',
6112
- hardRefresh: sessionStorage.getItem('dbg:hard-refresh') === 'on',
6113
- viewOrigins: sessionStorage.getItem('dbg:view-origins') === 'on',
6114
- extensionCatalogue: sessionStorage.getItem('dbg:extension-catalogue') !== 'off',
6115
- clearConsole: sessionStorage.getItem('dbg:clear-console') === 'on',
6212
+ viewState: sessionStorage.getItem(settingsKeys.viewState) !== 'off',
6213
+ loadPilets: sessionStorage.getItem(settingsKeys.loadPilets) === 'on',
6214
+ hardRefresh: sessionStorage.getItem(settingsKeys.hardRefresh) === 'on',
6215
+ viewOrigins: sessionStorage.getItem(settingsKeys.viewOrigins) === 'on',
6216
+ extensionCatalogue: sessionStorage.getItem(settingsKeys.extensionCatalogue) !== 'off',
6217
+ clearConsole: sessionStorage.getItem(settingsKeys.clearConsole) === 'on',
6116
6218
  persistSettings: persistSettings,
6117
6219
  cataloguePath: '/$debug-extension-catalogue'
6118
6220
  };
@@ -7643,6 +7745,13 @@ __webpack_require__.r(__webpack_exports__);
7643
7745
  });
7644
7746
 
7645
7747
  return {
7748
+ get path() {
7749
+ if (_nav) {
7750
+ return _nav.location.pathname;
7751
+ }
7752
+
7753
+ return location.pathname;
7754
+ },
7646
7755
  push(target, state) {
7647
7756
  if (_nav) {
7648
7757
  _nav.push(target, state);
@@ -45696,4 +45805,4 @@ var instance = (0,piral_core__WEBPACK_IMPORTED_MODULE_2__.createInstance)({
45696
45805
 
45697
45806
  /******/ })()
45698
45807
  ;
45699
- //# sourceMappingURL=index.b77a5c.js.map
45808
+ //# sourceMappingURL=index.8da693.js.map