@useinsider/guido 3.2.0-beta.803b92e → 3.2.0-beta.847c949

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 (50) hide show
  1. package/README.md +1 -25
  2. package/dist/@types/config/schemas.js +36 -38
  3. package/dist/components/Guido.vue.js +4 -4
  4. package/dist/components/Guido.vue2.js +34 -35
  5. package/dist/components/organisms/header/RightSlot.vue.js +8 -8
  6. package/dist/components/organisms/header/RightSlot.vue2.js +8 -9
  7. package/dist/components/organisms/onboarding/AMPOnboarding.vue2.js +51 -31
  8. package/dist/components/organisms/onboarding/GenericOnboarding.vue.js +1 -1
  9. package/dist/components/organisms/onboarding/GenericOnboarding.vue2.js +23 -22
  10. package/dist/components/organisms/onboarding/ItemsOnboarding.vue.js +1 -1
  11. package/dist/components/organisms/onboarding/ItemsOnboarding.vue2.js +37 -39
  12. package/dist/components/organisms/onboarding/TextBlockOnboarding.vue.js +3 -3
  13. package/dist/components/organisms/onboarding/TextBlockOnboarding.vue2.js +30 -41
  14. package/dist/components/organisms/onboarding/VersionHistoryOnboarding.vue2.js +15 -14
  15. package/dist/composables/useRibbonOffset.js +21 -0
  16. package/dist/composables/useSave.js +15 -15
  17. package/dist/config/compiler/unsubscribeCompilerRules.js +40 -37
  18. package/dist/enums/onboarding.js +7 -2
  19. package/dist/enums/unsubscribe.js +34 -27
  20. package/dist/extensions/Blocks/Recommendation/block.js +41 -38
  21. package/dist/extensions/Blocks/Recommendation/services/configService.js +4 -2
  22. package/dist/guido.css +1 -1
  23. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +258 -235
  24. package/dist/package.json.js +1 -1
  25. package/dist/src/@types/config/schemas.d.ts +0 -4
  26. package/dist/src/components/Guido.vue.d.ts +1 -1
  27. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +1 -1
  28. package/dist/src/components/organisms/header/HeaderWrapper.vue.d.ts +1 -1
  29. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  30. package/dist/src/composables/useConfig.d.ts +0 -2
  31. package/dist/src/composables/useRibbonOffset.d.ts +4 -0
  32. package/dist/src/composables/useSave.d.ts +1 -1
  33. package/dist/src/enums/onboarding.d.ts +6 -0
  34. package/dist/src/enums/unsubscribe.d.ts +5 -0
  35. package/dist/src/stores/config.d.ts +0 -18
  36. package/dist/src/stores/onboarding.d.ts +4 -0
  37. package/dist/stores/onboarding.js +4 -0
  38. package/package.json +3 -3
  39. package/dist/components/organisms/AutoSaveController.vue.js +0 -17
  40. package/dist/components/organisms/AutoSaveController.vue2.js +0 -13
  41. package/dist/components/organisms/header/AutoSaveToggle.vue.js +0 -22
  42. package/dist/components/organisms/header/AutoSaveToggle.vue2.js +0 -19
  43. package/dist/composables/useAutoSave.js +0 -68
  44. package/dist/src/components/organisms/AutoSaveController.vue.d.ts +0 -2
  45. package/dist/src/components/organisms/header/AutoSaveToggle.vue.d.ts +0 -2
  46. package/dist/src/composables/useAutoSave.d.ts +0 -3
  47. package/dist/src/stores/autosave.d.ts +0 -6
  48. package/dist/src/utils/timeUtil.d.ts +0 -8
  49. package/dist/stores/autosave.js +0 -11
  50. package/dist/utils/timeUtil.js +0 -19
@@ -1,15 +1,15 @@
1
1
  var k = Object.defineProperty;
2
- var I = (r, n, t) => n in r ? k(r, n, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[n] = t;
3
- var u = (r, n, t) => I(r, typeof n != "symbol" ? n + "" : n, t);
2
+ var I = (s, n, t) => n in s ? k(s, n, { enumerable: !0, configurable: !0, writable: !0, value: t }) : s[n] = t;
3
+ var u = (s, n, t) => I(s, typeof n != "symbol" ? n + "" : n, t);
4
4
  import { BlockId as B } from "../../../enums/block.js";
5
5
  import { getMigrationBannerHtml as _ } from "../../../utils/migrationBannerHtml.js";
6
- import { Block as b, BlockCompositionType as R, ModificationDescription as y } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
7
- import { regenerateMobileProductRows as C } from "./controls/main/utils.js";
6
+ import { Block as b, BlockCompositionType as R, ModificationDescription as C } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
7
+ import { regenerateMobileProductRows as y } from "./controls/main/utils.js";
8
8
  import { ensureMobileCssRulesExist as g, setMobileLayoutOptOut as d, hasMobileLayoutOptOut as A } from "./controls/mobileLayout/cssRules.js";
9
- import { RecommendationConfigService as c } from "./services/configService.js";
9
+ import { RecommendationConfigService as r } from "./services/configService.js";
10
10
  import { useRecommendationExtensionStore as p } from "./store/recommendation.js";
11
- import { getDefaultTemplate as E } from "./templates/grid/template.js";
12
- const f = B.Recommendation, a = "recommendation-block-v2", l = "recommendation-id";
11
+ import { getDefaultTemplate as D } from "./templates/grid/template.js";
12
+ const f = B.Recommendation, l = "recommendation-block-v2", m = "recommendation-id";
13
13
  let h = !1;
14
14
  class q extends b {
15
15
  constructor() {
@@ -56,7 +56,7 @@ class q extends b {
56
56
  */
57
57
  getTemplate() {
58
58
  const t = this._generateNextId();
59
- return this._pendingBlockId = t, E(t);
59
+ return this._pendingBlockId = t, D(t);
60
60
  }
61
61
  /**
62
62
  * Called when a new block is dropped into the template
@@ -66,15 +66,18 @@ class q extends b {
66
66
  * @param node - The newly created block node
67
67
  */
68
68
  onCreated(t) {
69
- const e = this._pendingBlockId ?? this._generateNextId();
70
- this._pendingBlockId = null, this._assignRecommendationId(t, e);
71
- const o = c.initializeConfig(this.api, t, { recommendationId: e }), i = p();
72
- i.setCurrentBlock(e), g(this.api);
73
- const s = this._getBlockElement(t);
74
- s && (d(this.api, s, !0), C({
75
- currentNode: t,
76
- documentModifier: this.api.getDocumentModifier()
77
- })), i.patchCurrentBlockConfig({ language: o.language }, { triggerRefetch: !1 });
69
+ const e = !r.hasConfig(t), i = this._pendingBlockId ?? this._generateNextId();
70
+ this._pendingBlockId = null, this._assignRecommendationId(t, i);
71
+ const o = r.initializeConfig(this.api, t, { recommendationId: i }), c = p();
72
+ if (c.setCurrentBlock(i), e) {
73
+ g(this.api);
74
+ const a = this._getBlockElement(t);
75
+ a && (d(this.api, a, !0), y({
76
+ currentNode: t,
77
+ documentModifier: this.api.getDocumentModifier()
78
+ }));
79
+ }
80
+ c.patchCurrentBlockConfig({ language: o.language }, { triggerRefetch: !1 });
78
81
  }
79
82
  /**
80
83
  * Called when the document changes or template is loaded
@@ -87,20 +90,20 @@ class q extends b {
87
90
  if (!(!t || !("getNodeConfig" in t))) {
88
91
  if (!this._getRecommendationId(t)) {
89
92
  const e = this._generateNextId();
90
- this._assignRecommendationId(t, e), c.hasConfig(t) && c.updateConfig(
93
+ this._assignRecommendationId(t, e), r.hasConfig(t) && r.updateConfig(
91
94
  this.api,
92
95
  t,
93
96
  { recommendationId: e },
94
97
  "Assign recommendation ID to legacy block"
95
98
  );
96
99
  }
97
- c.needsMigration(t) && this._migrateFromLegacy(t);
100
+ r.needsMigration(t) && this._migrateFromLegacy(t);
98
101
  try {
99
102
  h || (g(this.api), h = !0);
100
- const e = c.getConfig(t), o = this._getBlockElement(t);
101
- if (o) {
102
- const i = !e.mobileLayoutEnabled;
103
- A(o) !== i && d(this.api, o, i);
103
+ const e = r.getConfig(t), i = this._getBlockElement(t);
104
+ if (i) {
105
+ const o = !e.mobileLayoutEnabled;
106
+ A(i) !== o && d(this.api, i, o);
104
107
  }
105
108
  } catch {
106
109
  }
@@ -124,10 +127,10 @@ class q extends b {
124
127
  let t = 0;
125
128
  try {
126
129
  const e = this.api.getDocumentRoot();
127
- e && "querySelectorAll" in e && e.querySelectorAll(`.${a}`).forEach((i) => {
128
- if ("getAttribute" in i) {
129
- const s = i.getAttribute(l), m = s ? parseInt(s) : 0;
130
- m > t && (t = m);
130
+ e && "querySelectorAll" in e && e.querySelectorAll(`.${l}`).forEach((o) => {
131
+ if ("getAttribute" in o) {
132
+ const c = o.getAttribute(m), a = c ? parseInt(c) : 0;
133
+ a > t && (t = a);
131
134
  }
132
135
  });
133
136
  } catch {
@@ -141,11 +144,11 @@ class q extends b {
141
144
  * added classes via setAttribute.
142
145
  */
143
146
  _assignRecommendationId(t, e) {
144
- const o = this._getBlockElement(t);
145
- if (!o)
147
+ const i = this._getBlockElement(t);
148
+ if (!i)
146
149
  return;
147
- const i = this.api.getDocumentModifier();
148
- i.modifyHtml(o).setAttribute(l, e.toString()), i.apply(new y(`Assign recommendation ID ${e}`));
150
+ const o = this.api.getDocumentModifier();
151
+ o.modifyHtml(i).setAttribute(m, e.toString()), o.apply(new C(`Assign recommendation ID ${e}`));
149
152
  }
150
153
  /**
151
154
  * Gets the recommendation-id from a block node
@@ -154,11 +157,11 @@ class q extends b {
154
157
  const e = this._getBlockElement(t);
155
158
  if (!e || !("getAttribute" in e))
156
159
  return null;
157
- const o = e.getAttribute(l);
158
- if (!o)
160
+ const i = e.getAttribute(m);
161
+ if (!i)
159
162
  return null;
160
- const i = parseInt(o);
161
- return Number.isNaN(i) ? null : i;
163
+ const o = parseInt(i);
164
+ return Number.isNaN(o) ? null : o;
162
165
  }
163
166
  /**
164
167
  * Gets the block element (the element with BLOCK_CLASS)
@@ -166,16 +169,16 @@ class q extends b {
166
169
  _getBlockElement(t) {
167
170
  if ("getAttribute" in t) {
168
171
  const e = t.getAttribute("class");
169
- if (e && e.includes(a))
172
+ if (e && e.includes(l))
170
173
  return t;
171
174
  }
172
- return "querySelector" in t ? t.querySelector(`.${a}`) ?? null : null;
175
+ return "querySelector" in t ? t.querySelector(`.${l}`) ?? null : null;
173
176
  }
174
177
  /**
175
178
  * Migrate configuration from legacy format
176
179
  */
177
180
  _migrateFromLegacy(t) {
178
- c.migrateFromDataAttributes(this.api, t);
181
+ r.migrateFromDataAttributes(this.api, t);
179
182
  }
180
183
  }
181
184
  export {
@@ -1,7 +1,7 @@
1
1
  import { ModificationDescription as f } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
2
  import { CURRENT_CONFIG_VERSION as u, DEFAULT_NODE_CONFIG as e } from "../constants/defaultConfig.js";
3
3
  import { setCurrencyAttributes as g } from "../controls/main/utils.js";
4
- import { hasMinimalConfig as a } from "../types/nodeConfig.js";
4
+ import { hasMinimalConfig as m } from "../types/nodeConfig.js";
5
5
  class C {
6
6
  // ========================================================================
7
7
  // Read Operations
@@ -42,7 +42,7 @@ class C {
42
42
  return !1;
43
43
  try {
44
44
  const t = i.getNodeConfig();
45
- return a(t);
45
+ return m(t);
46
46
  } catch {
47
47
  return !1;
48
48
  }
@@ -94,6 +94,8 @@ class C {
94
94
  * @returns The initialized configuration
95
95
  */
96
96
  static initializeConfig(i, t, o) {
97
+ if (this.hasConfig(t))
98
+ return o ? this.updateConfig(i, t, o, "Initialize recommendation block") : this.getConfig(t);
97
99
  const n = o ? this.mergeWithDefaults(o) : this.cloneDefaults();
98
100
  return this.saveConfig(i, t, n, "Initialize recommendation block"), g({
99
101
  currentNode: t,
package/dist/guido.css CHANGED
@@ -1 +1 @@
1
- .gap-16[data-v-3b53a736],.gap-16[data-v-0e1b0c54]{gap:16px}[data-v-cd76c125] .in-button-v2__wrapper{line-height:0}[data-v-22226124] .in-segments-wrapper__button_selected,[data-v-22226124] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb;color:#0010ac;border-color:#0010ac}[data-v-2cb418af] .in-progress-wrapper__progress p span:last-child{display:none!important}[data-v-2cb418af] .in-progress-description-status{display:none!important}.view-options-wrapper[data-v-195ab6d4]{position:relative;display:inline-block}.new-tag[data-v-195ab6d4]{position:absolute;top:-8px;right:-16px;z-index:10}[data-v-195ab6d4] .guido__view-option-selection-desktop svg,[data-v-195ab6d4] .guido__view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-195ab6d4] .in-segments-wrapper__button_selected,[data-v-195ab6d4] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}[data-v-195ab6d4] .in-tooltip-wrapper__icon{cursor:pointer}.editor-toolbar[data-v-173c3a40]{gap:4px}.version-history-item[data-v-ee4b9c3f]{flex-basis:200px}.version-history[data-v-64c52560]{gap:8px}.version-history__toolbar[data-v-64c52560]{gap:4px}.view-options-wrapper[data-v-d405ca59]{position:relative;display:inline-block}.new-tag[data-v-d405ca59]{position:absolute;top:-8px;right:-16px;z-index:10}[data-v-d405ca59] .guido__verion-history-view-option-selection-desktop svg,[data-v-d405ca59] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-d405ca59] .in-segments-wrapper__button_selected,[data-v-d405ca59] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}[data-v-d405ca59] .in-tooltip-wrapper__icon{cursor:pointer}.auto-save-toggle[data-v-4cbf0abd]{position:relative}.auto-save-toggle__info-box[data-v-4cbf0abd]{position:absolute;top:100%;left:0;z-index:10;width:280px}.editor-actions[data-v-4e2a4adb]{gap:4px}.header-wrapper[data-v-5c02dcc7]{min-width:1000px}.guido-loading__wrapper[data-v-07c4b2d8]{height:100%;top:75px!important;bottom:0!important}.guido-editor__wrapper[data-v-fffc13d6]{--ribbon-offset: 0px;position:relative;width:100%;height:calc(100vh - 128px - var(--ribbon-offset))}.guido-editor__container[data-v-fffc13d6]{width:100%;height:calc(100vh - 128px - var(--ribbon-offset))}.guido-editor__no-header[data-v-fffc13d6]{height:calc(100vh - 75px - var(--ribbon-offset))}[data-v-293f1c47] .in-breadcrumb-wrapper__links{cursor:pointer}.templates-wrapper[data-v-df672485]{gap:16px;grid-template-columns:repeat(3,1fr)}.templates-wrapper .template-wrapper[data-v-df672485]{cursor:pointer}.templates-wrapper .template-wrapper .template-container[data-v-df672485]{height:274px;padding:2px;transition:none}.templates-wrapper .template-wrapper .template-container.selected[data-v-df672485]{padding:1px}.templates-wrapper .template-wrapper .template-container .thumbnail[data-v-df672485]{object-fit:cover;transform:scale(1)}[data-v-43c617a7] .guido__verion-history-view-option-selection-desktop svg,[data-v-43c617a7] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-43c617a7] .in-segments-wrapper__button_selected,[data-v-43c617a7] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}.error-list[data-v-c3fd5d4b]{gap:16px}.desktop-browser-header[data-v-d86c5af5]{height:79px;min-height:79px}.desktop-browser-header__left[data-v-d86c5af5]{-webkit-user-drag:none;height:79px;width:378px}.desktop-browser-header__center[data-v-d86c5af5]{height:79px;background-repeat:repeat-x;background-size:auto 100%;background-position:left top}.desktop-browser-header__right[data-v-d86c5af5]{-webkit-user-drag:none;height:79px;width:112px}.desktop-preview[data-v-988f8da6]{min-width:602px;height:70vh;min-height:583px;border-radius:10px}.desktop-preview iframe[data-v-988f8da6]{min-height:504px}.iframe-wrapper[data-v-e0424e99]{width:258px}.iframe-scaled[data-v-e0424e99]{width:320px;height:124.0310077519%;transform:scale(.80625);transform-origin:top left}.cropped-text[data-v-eb3d05d7]{width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-preview-wrapper__phone[data-v-3f472f96]{width:282px}.mobile-preview-wrapper__phone img[data-v-3f472f96]{object-fit:cover;border-radius:44px}.mobile-preview-wrapper__content[data-v-3f472f96]{width:258px;height:450px;left:12px}[data-v-29b9af29] .vueperslides__bullets,[data-v-dd1a237a] .vueperslides__bullets{pointer-events:none!important}[data-v-dd1a237a] .vueperslides__parallax-wrapper{height:110px!important}[data-v-d073b1dc] .vueperslides__bullets{pointer-events:none!important}[data-v-d073b1dc] .vueperslides__parallax-wrapper{height:110px!important}
1
+ .gap-16[data-v-3b53a736],.gap-16[data-v-0e1b0c54]{gap:16px}[data-v-cd76c125] .in-button-v2__wrapper{line-height:0}[data-v-22226124] .in-segments-wrapper__button_selected,[data-v-22226124] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb;color:#0010ac;border-color:#0010ac}[data-v-2cb418af] .in-progress-wrapper__progress p span:last-child{display:none!important}[data-v-2cb418af] .in-progress-description-status{display:none!important}.view-options-wrapper[data-v-195ab6d4]{position:relative;display:inline-block}.new-tag[data-v-195ab6d4]{position:absolute;top:-8px;right:-16px;z-index:10}[data-v-195ab6d4] .guido__view-option-selection-desktop svg,[data-v-195ab6d4] .guido__view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-195ab6d4] .in-segments-wrapper__button_selected,[data-v-195ab6d4] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}[data-v-195ab6d4] .in-tooltip-wrapper__icon{cursor:pointer}.editor-toolbar[data-v-173c3a40]{gap:4px}.version-history-item[data-v-ee4b9c3f]{flex-basis:200px}.version-history[data-v-64c52560]{gap:8px}.version-history__toolbar[data-v-64c52560]{gap:4px}.view-options-wrapper[data-v-d405ca59]{position:relative;display:inline-block}.new-tag[data-v-d405ca59]{position:absolute;top:-8px;right:-16px;z-index:10}[data-v-d405ca59] .guido__verion-history-view-option-selection-desktop svg,[data-v-d405ca59] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-d405ca59] .in-segments-wrapper__button_selected,[data-v-d405ca59] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}[data-v-d405ca59] .in-tooltip-wrapper__icon{cursor:pointer}.editor-actions[data-v-4e2a4adb]{gap:4px}.header-wrapper[data-v-5c02dcc7]{min-width:1000px}.guido-loading__wrapper[data-v-07c4b2d8]{height:100%;top:75px!important;bottom:0!important}.guido-editor__wrapper[data-v-25780af6]{--ribbon-offset: 0px;position:relative;width:100%;height:calc(100vh - 128px - var(--ribbon-offset))}.guido-editor__container[data-v-25780af6]{width:100%;height:calc(100vh - 128px - var(--ribbon-offset))}.guido-editor__no-header[data-v-25780af6]{height:calc(100vh - 75px - var(--ribbon-offset))}[data-v-293f1c47] .in-breadcrumb-wrapper__links{cursor:pointer}.templates-wrapper[data-v-df672485]{gap:16px;grid-template-columns:repeat(3,1fr)}.templates-wrapper .template-wrapper[data-v-df672485]{cursor:pointer}.templates-wrapper .template-wrapper .template-container[data-v-df672485]{height:274px;padding:2px;transition:none}.templates-wrapper .template-wrapper .template-container.selected[data-v-df672485]{padding:1px}.templates-wrapper .template-wrapper .template-container .thumbnail[data-v-df672485]{object-fit:cover;transform:scale(1)}[data-v-43c617a7] .guido__verion-history-view-option-selection-desktop svg,[data-v-43c617a7] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-43c617a7] .in-segments-wrapper__button_selected,[data-v-43c617a7] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}.error-list[data-v-c3fd5d4b]{gap:16px}.desktop-browser-header[data-v-d86c5af5]{height:79px;min-height:79px}.desktop-browser-header__left[data-v-d86c5af5]{-webkit-user-drag:none;height:79px;width:378px}.desktop-browser-header__center[data-v-d86c5af5]{height:79px;background-repeat:repeat-x;background-size:auto 100%;background-position:left top}.desktop-browser-header__right[data-v-d86c5af5]{-webkit-user-drag:none;height:79px;width:112px}.desktop-preview[data-v-988f8da6]{min-width:602px;height:70vh;min-height:583px;border-radius:10px}.desktop-preview iframe[data-v-988f8da6]{min-height:504px}.iframe-wrapper[data-v-e0424e99]{width:258px}.iframe-scaled[data-v-e0424e99]{width:320px;height:124.0310077519%;transform:scale(.80625);transform-origin:top left}.cropped-text[data-v-eb3d05d7]{width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-preview-wrapper__phone[data-v-3f472f96]{width:282px}.mobile-preview-wrapper__phone img[data-v-3f472f96]{object-fit:cover;border-radius:44px}.mobile-preview-wrapper__content[data-v-3f472f96]{width:258px;height:450px;left:12px}[data-v-7419ae06] .vueperslides__bullets,[data-v-796d193b] .vueperslides__bullets{pointer-events:none!important}[data-v-796d193b] .vueperslides__parallax-wrapper{height:110px!important}[data-v-cadfc82d] .vueperslides__bullets{pointer-events:none!important}[data-v-cadfc82d] .vueperslides__parallax-wrapper{height:110px!important}