@myissue/vue-website-page-builder 3.2.86 → 3.2.91

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 (59) hide show
  1. package/README.md +46 -3
  2. package/dist/vue-website-page-builder.css +1 -1
  3. package/dist/vue-website-page-builder.js +9217 -9022
  4. package/dist/vue-website-page-builder.umd.cjs +38 -38
  5. package/package.json +2 -2
  6. package/src/Components/Homepage/Footer.vue +9 -7
  7. package/src/Components/Homepage/Navbar.vue +6 -4
  8. package/src/Components/Layouts/FullWidthElement.vue +6 -6
  9. package/src/Components/Modals/BuilderComponents.vue +12 -6
  10. package/src/Components/Modals/DynamicModalBuilder.vue +39 -47
  11. package/src/Components/Modals/MediaLibraryModal.vue +2 -2
  12. package/src/Components/Modals/ModalBuilder.vue +23 -19
  13. package/src/Components/PageBuilder/DefaultComponents/DefaultBuilderComponents.vue +29 -17
  14. package/src/Components/PageBuilder/DefaultComponents/DefaultMediaLibraryComponent.vue +2 -2
  15. package/src/Components/PageBuilder/EditorMenu/Editables/BackgroundColorEditor.vue +22 -20
  16. package/src/Components/PageBuilder/EditorMenu/Editables/BorderRadius.vue +17 -17
  17. package/src/Components/PageBuilder/EditorMenu/Editables/Borders.vue +28 -26
  18. package/src/Components/PageBuilder/EditorMenu/Editables/ClassEditor.vue +13 -11
  19. package/src/Components/PageBuilder/EditorMenu/Editables/ComponentTopMenu.vue +5 -5
  20. package/src/Components/PageBuilder/EditorMenu/Editables/DeleteElement.vue +4 -4
  21. package/src/Components/PageBuilder/EditorMenu/Editables/EditGetElement.vue +22 -19
  22. package/src/Components/PageBuilder/EditorMenu/Editables/ElementEditor.vue +11 -11
  23. package/src/Components/PageBuilder/EditorMenu/Editables/ImageEditor.vue +4 -4
  24. package/src/Components/PageBuilder/EditorMenu/Editables/LinkEditor.vue +74 -66
  25. package/src/Components/PageBuilder/EditorMenu/Editables/ManageBackgroundOpacity.vue +26 -21
  26. package/src/Components/PageBuilder/EditorMenu/Editables/ManageOpacity.vue +26 -21
  27. package/src/Components/PageBuilder/EditorMenu/Editables/Margin.vue +101 -0
  28. package/src/Components/PageBuilder/EditorMenu/Editables/OpacityEditor.vue +2 -3
  29. package/src/Components/PageBuilder/EditorMenu/Editables/{PaddingPlusMargin.vue → Padding.vue} +8 -41
  30. package/src/Components/PageBuilder/EditorMenu/Editables/TextColorEditor.vue +22 -20
  31. package/src/Components/PageBuilder/EditorMenu/Editables/Typography.vue +63 -58
  32. package/src/Components/PageBuilder/EditorMenu/EditorAccordion.vue +7 -4
  33. package/src/Components/PageBuilder/EditorMenu/RightSidebarEditor.vue +24 -19
  34. package/src/Components/PageBuilder/Settings/AdvancedPageBuilderSettings.vue +132 -98
  35. package/src/Components/PageBuilder/Settings/PageBuilderSettings.vue +216 -146
  36. package/src/Components/PageBuilder/ToolbarOption/ToolbarOption.vue +14 -14
  37. package/src/Components/TipTap/TipTap.vue +4 -4
  38. package/src/Components/TipTap/TipTapInput.vue +39 -33
  39. package/src/DemoComponents/DemoBuilderComponents.vue +1 -1
  40. package/src/DemoComponents/DemoUnsplash.vue +79 -56
  41. package/src/DemoComponents/HomeSection.vue +20 -16
  42. package/src/DemoComponents/html.json +4 -4
  43. package/src/PageBuilder/PageBuilder.vue +62 -57
  44. package/src/PageBuilder/Preview.vue +4 -20
  45. package/src/composables/PageBuilderClass.ts +66 -120
  46. package/src/css/app.css +161 -448
  47. package/src/css/dev-global.css +137 -0
  48. package/src/main.ts +1 -0
  49. package/src/tailwind-safelist.html +1 -1
  50. package/src/utils/builder/tailwaind-colors.ts +488 -488
  51. package/src/utils/builder/tailwind-border-radius.ts +40 -40
  52. package/src/utils/builder/tailwind-border-style-width-color.ts +231 -231
  53. package/src/utils/builder/tailwind-font-sizes.ts +56 -57
  54. package/src/utils/builder/tailwind-font-styles.ts +44 -11
  55. package/src/utils/builder/tailwind-opacities.ts +30 -30
  56. package/src/utils/builder/tailwind-padding-margin.ts +136 -136
  57. package/dist/components.json +0 -36
  58. package/src/Components/Loaders/FullScreenSpinner.vue +0 -9
  59. package/src/Components/Loaders/SmallUniversalSpinner.vue +0 -26
@@ -110,12 +110,12 @@ onMounted(async () => {
110
110
 
111
111
  <template>
112
112
  <div>
113
- <div class="myPrimaryWidthScreenModule bg-red-50 lg:block">
114
- <div class="myPrimaryContentSection">
115
- <h2 class="mySecondaryHeader">
113
+ <div class="pbx-myPrimaryWidthScreenModule pbx-bg-red-50 lg:pbx-block">
114
+ <div class="pbx-myPrimaryContentSection">
115
+ <h2 class="pbx-mySecondaryHeader">
116
116
  Bring your vision to life and create impressive pages using a click & drop Page Builder
117
117
  </h2>
118
- <p class="myPrimaryParagraph font-normal">
118
+ <p class="pbx-myPrimaryParagraph pbx-font-normal">
119
119
  The web builder for stunning pages. Enable users to design and publish modern pages at any
120
120
  scale. Build responsive pages like listings, jobs or blog posts and manage content easily
121
121
  using the free click & drop Page Builder. Developed with TypeScript, Vue 3, Composition
@@ -123,13 +123,13 @@ onMounted(async () => {
123
123
 
124
124
  <br />
125
125
  </p>
126
- <div class="mt-4">
127
- <p class="myPrimaryParagraph font-normal">
126
+ <div class="pbx-mt-4">
127
+ <p class="pbx-myPrimaryParagraph pbx-font-normal">
128
128
  Download or install our powerful, flexible, and easy-to-use free Vue 3 Page Builder via
129
129
  <br />
130
130
  <strong> npm:</strong>
131
131
  <a
132
- class="text-myPrimaryLinkColor"
132
+ class="pbx-text-myPrimaryLinkColor"
133
133
  href="https://www.npmjs.com/package/@myissue/vue-website-page-builder"
134
134
  target="_blank"
135
135
  >
@@ -138,32 +138,36 @@ onMounted(async () => {
138
138
  </p>
139
139
  </div>
140
140
  </div>
141
- <div class="m-4">
141
+ <div class="pbx-m-4">
142
142
  <!-- :CustomBuilderComponents="DemoBuilderComponents" -->
143
143
  <PageBuilder :CustomMediaLibraryComponent="DemoMediaLibraryComponent"></PageBuilder>
144
144
  </div>
145
145
  </div>
146
146
 
147
- <FullWidthElement :descriptionArea="true" class="bg-gray-50">
147
+ <FullWidthElement :descriptionArea="true" class="pbx-bg-gray-50">
148
148
  <template #title>Everything you need. Break free from design limitations </template>
149
149
  <template #description>
150
- <p class="myPrimaryParagraph font-normal">
150
+ <p class="pbx-myPrimaryParagraph pbx-font-normal">
151
151
  A Page Builder designed for growth. Build your website pages with ready-made components
152
152
  that are fully customizable and always responsive, designed to fit every need. A powerful
153
153
  Page Builder for growing merchants, brands, and agencies.
154
154
  </p>
155
155
  </template>
156
156
  <template #content>
157
- <div class="grid grid-cols-1 gap-8 sm:grid-cols-2 md:grid-cols-2 lg:grid-cols-4 mt-8">
157
+ <div
158
+ class="pbx-grid pbx-grid-cols-1 pbx-gap-8 sm:pbx-grid-cols-2 md:pbx-grid-cols-2 lg:pbx-grid-cols-4 pbx-mt-8"
159
+ >
158
160
  <div
159
161
  v-for="feature in features"
160
162
  :key="feature.name"
161
- class="bg-red-200 bg-opacity-20 hover:bg-opacity-10 w-full lg:min-h-[20rem] min-h-[12rem] relative col-span-1 flex flex-col text-center rounded-lg shadow-sm outline outline-2 outline-offset-8 outline-yellow-400"
163
+ class="pbx-bg-red-200 pbx-bg-opacity-20 hover:pbx-bg-opacity-10 pbx-w-full lg:pbx-min-h-[20rem] pbx-min-h-[12rem] pbx-relative pbx-col-span-1 pbx-flex pbx-flex-col pbx-text-center pbx-rounded-lg pbx-shadow-sm pbx-outline pbx-outline-2 pbx-outline-offset-8 pbx-outline-yellow-400"
162
164
  >
163
- <div class="bg-black/0 absolute top-0 left-0 w-full h-full rounded-lg"></div>
164
- <div class="px-2 pt-8 absolute top-0 w-full">
165
- <p class="myTertiaryHeader">{{ feature.name }}</p>
166
- <p class="myPrimaryParagraph font-medium drop-shadow-sm">
165
+ <div
166
+ class="pbx-bg-black/0 pbx-absolute pbx-top-0 pbx-left-0 pbx-w-full pbx-h-full pbx-rounded-lg"
167
+ ></div>
168
+ <div class="pbx-px-2 pbx-pt-8 pbx-absolute pbx-top-0 pbx-w-full">
169
+ <p class="pbx-myTertiaryHeader">{{ feature.name }}</p>
170
+ <p class="pbx-myPrimaryParagraph pbx-font-medium pbx-drop-shadow-sm">
167
171
  {{ feature.description }}
168
172
  </p>
169
173
  </div>
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "components": [
3
3
  {
4
- "html_code": "<section><div class=\"relative py-4\"><div class=\"mx-auto max-w-7xl lg:px-4 px-2\"><div class=\"break-words\"><h2><strong>Demo Content</strong></h2></div></div></div></section>",
4
+ "html_code": "<section><div class=\"relative py-4\"><div class=\"mx-auto max-w-7xl lg:px-4 px-2\"><div class=\"pbx-break-words pbx-text-5xl\"><h2><strong>Demo Content</strong></h2></div></div></div></section>",
5
5
  "title": "Header H2"
6
6
  },
7
7
  {
@@ -10,12 +10,12 @@
10
10
  "title": "Text"
11
11
  },
12
12
  {
13
- "html_code": "<section>\n<div class=\"w-full md:pt-12 md:pb-12 pt-4 pb-4 lg:px-4 px-2 bg-black\"><div class=\"mx-auto max-w-7xl\"><div class=\"myPrimaryGap grid grid-cols-1 sm:grid-cols-3 lg:grid-cols-3\"> <div class=\"flex-1 py-2\"> <img class=\"object-cover w-full object-top aspect-[9/16] smooth-transition rounded-tl-full\" src=\"https://images.unsplash.com/photo-1632765866070-3fadf25d3d5b?crop=entropy&amp;cs=tinysrgb&amp;fit=max&amp;fm=jpg&amp;ixid=M3wzMTI0Mzl8MHwxfHNlYXJjaHwxMjh8fG1vZGVsfGVufDB8fHx8MTc0OTgzMDgzMXww&amp;ixlib=rb-4.1.0&amp;q=80&amp;w=1080\" alt=\"provider\" data-image=\"b2fb2e61-c916-4195-9cd2-c1d25747b4f7\"> </div> <div class=\"flex-1 py-2\"> <img class=\"object-cover w-full object-top aspect-[9/16] smooth-transition rounded-full\" src=\"https://images.unsplash.com/photo-1542513217-0b0eedf7005d?crop=entropy&amp;cs=tinysrgb&amp;fit=max&amp;fm=jpg&amp;ixid=M3wzMTI0Mzl8MHwxfHNlYXJjaHwxMDR8fG1vZGVsfGVufDB8fHx8MTc0OTgzMDc5MXww&amp;ixlib=rb-4.1.0&amp;q=80&amp;w=1080\" alt=\"provider\" data-image=\"fdf36a14-f7ef-4025-942f-c87b20b18005\"> </div> <div class=\"flex-1 py-2\"> <img class=\"object-cover w-full object-top aspect-[9/16] smooth-transition rounded-br-full\" src=\"https://images.unsplash.com/photo-1574015974293-817f0ebebb74?crop=entropy&amp;cs=tinysrgb&amp;fit=max&amp;fm=jpg&amp;ixid=M3wzMTI0Mzl8MHwxfHNlYXJjaHwyNnx8bW9kZWx8ZW58MHx8fHwxNzQ5ODMwNzM1fDA&amp;ixlib=rb-4.1.0&amp;q=80&amp;w=1080\" alt=\"provider\" data-image=\"618a74a7-5d41-4dce-937c-130dd7490569\"></div></div> </div></div>\n</section>",
13
+ "html_code": "<section>\n<div class=\"w-full md:pt-12 md:pb-12 pt-4 pb-4 lg:px-4 px-2 bg-black\"><div class=\"mx-auto max-w-7xl m\"><div class=\"myPrimaryGap grid grid-cols-1 sm:grid-cols-3 lg:grid-cols-3\"> <div class=\"flex-1 py-2\"> <img class=\"object-cover w-full object-top aspect-[9/16] smooth-transition rounded-tl-full\" src=\"https://images.unsplash.com/photo-1632765866070-3fadf25d3d5b?crop=entropy&amp;cs=tinysrgb&amp;fit=max&amp;fm=jpg&amp;ixid=M3wzMTI0Mzl8MHwxfHNlYXJjaHwxMjh8fG1vZGVsfGVufDB8fHx8MTc0OTgzMDgzMXww&amp;ixlib=rb-4.1.0&amp;q=80&amp;w=1080\" alt=\"provider\" data-image=\"b2fb2e61-c916-4195-9cd2-c1d25747b4f7\"> </div> <div class=\"flex-1 py-2\"> <img class=\"object-cover w-full object-top aspect-[9/16] smooth-transition rounded-full\" src=\"https://images.unsplash.com/photo-1542513217-0b0eedf7005d?crop=entropy&amp;cs=tinysrgb&amp;fit=max&amp;fm=jpg&amp;ixid=M3wzMTI0Mzl8MHwxfHNlYXJjaHwxMDR8fG1vZGVsfGVufDB8fHx8MTc0OTgzMDc5MXww&amp;ixlib=rb-4.1.0&amp;q=80&amp;w=1080\" alt=\"provider\" data-image=\"fdf36a14-f7ef-4025-942f-c87b20b18005\"> </div> <div class=\"flex-1 py-2\"> <img class=\"object-cover w-full object-top aspect-[9/16] smooth-transition rounded-br-full\" src=\"https://images.unsplash.com/photo-1574015974293-817f0ebebb74?crop=entropy&amp;cs=tinysrgb&amp;fit=max&amp;fm=jpg&amp;ixid=M3wzMTI0Mzl8MHwxfHNlYXJjaHwyNnx8bW9kZWx8ZW58MHx8fHwxNzQ5ODMwNzM1fDA&amp;ixlib=rb-4.1.0&amp;q=80&amp;w=1080\" alt=\"provider\" data-image=\"618a74a7-5d41-4dce-937c-130dd7490569\"></div></div> </div></div>\n</section>",
14
14
 
15
15
  "title": "3 Vertical Images"
16
16
  },
17
17
  {
18
- "html_code": "<section><div class=\"relative py-4\"><div class=\"mx-auto max-w-7xl lg:px-4 px-2\"><div class=\"break-words\"><h3>The web builder for stunning pages</h3></div></div></div></section>",
18
+ "html_code": "<section><div class=\"relative py-4\"><div class=\"mx-auto max-w-7xl lg:px-4 px-2\"><div class=\"pbx-break-words pbx-text-3xl mt-6\"><h3>The web builder for stunning pages</h3></div></div></div></section>",
19
19
 
20
20
  "title": "Header H3"
21
21
  },
@@ -30,7 +30,7 @@
30
30
  "title": "2 Vertical Images"
31
31
  },
32
32
  {
33
- "html_code": "<section><div class=\"relative py-4\" selected=\"\"><div class=\"mx-auto max-w-7xl lg:px-4 px-2\"><div class=\"break-words\"><h3>Just publish it with Vue</h3></div></div></div></section>",
33
+ "html_code": "<section><div class=\"relative py-4\" selected=\"\"><div class=\"mx-auto max-w-7xl lg:px-4 px-2\"><div class=\"pbx-break-words pbx-text-3xl mt-6\"><h3>Just publish it with Vue</h3></div></div></div></section>",
34
34
 
35
35
  "title": "Header H3"
36
36
  },
@@ -254,12 +254,12 @@ onMounted(async () => {
254
254
  <template>
255
255
  <div
256
256
  id="builder-container"
257
- class="font-sans max-w-full m-1 border border-gray-600 inset-x-0 z-10 bg-white overflow-x-scroll"
257
+ class="pbx-font-sans pbx-max-w-full pbx-m-1 pbx-border pbx-border-gray-400 pbx-inset-x-0 pbx-z-10 pbx-bg-white pbx-overflow-x-scroll"
258
258
  >
259
- <div id="pagebuilder-top-area" class="lg:px-4 pt-2 pb-4 mx-4 mb-4 mt-2">
259
+ <div id="pagebuilder-top-area" class="lg:pbx-px-4 pbx-pt-2 pbx-pb-4 pbx-mx-4 pbx-mb-4 pbx-mt-2">
260
260
  <div
261
261
  @click.self="pageBuilderClass.clearHtmlSelection()"
262
- class="flex justify-between items-center pb-2 border-b border-gray-200"
262
+ class="pbx-flex pbx-justify-between pbx-items-center pbx-pb-2 pbx-border-b pbx-border-gray-200"
263
263
  >
264
264
  <!-- Logo # start -->
265
265
  <div @click="pageBuilderClass.clearHtmlSelection()">
@@ -269,16 +269,16 @@ onMounted(async () => {
269
269
  getConfigPageBuilder.pageBuilderLogo &&
270
270
  getConfigPageBuilder.pageBuilderLogo.src
271
271
  "
272
- class="flex items-center divide-x divide-gray-200"
272
+ class="pbx-flex pbx-items-center pbx-divide-x pbx-divide-gray-200"
273
273
  >
274
- <div id="pagebuilder-logo-main" class="pr-4">
275
- <img class="h-6" :src="getConfigPageBuilder.pageBuilderLogo.src" alt="Logo" />
274
+ <div id="pagebuilder-logo-main" class="pbx-pr-4">
275
+ <img class="pbx-h-6" :src="getConfigPageBuilder.pageBuilderLogo.src" alt="Logo" />
276
276
  </div>
277
- <span class="myPrimaryParagraph font-medium pl-4">Editing Page </span>
277
+ <span class="pbx-myPrimaryParagraph pbx-font-medium pbx-pl-4">Editing Page </span>
278
278
  </div>
279
279
  <div v-else>
280
- <div class="pr-6">
281
- <span class="myPrimaryParagraph font-medium">Editing Page </span>
280
+ <div class="pbx-pr-6">
281
+ <span class="pbx-myPrimaryParagraph pbx-font-medium">Editing Page </span>
282
282
  </div>
283
283
  </div>
284
284
  </div>
@@ -329,14 +329,14 @@ onMounted(async () => {
329
329
  </DynamicModalBuilder>
330
330
 
331
331
  <div>
332
- <div class="relative h-full flex pb-2 gap-2">
332
+ <div class="pbx-relative pbx-h-full pbx-flex pbx-pb-2 pbx-gap-2">
333
333
  <div
334
334
  @click.self="pageBuilderClass.clearHtmlSelection()"
335
335
  id="pagebuilder-left-area"
336
- class="min-w-[3.5rem] pt-6 pb-2 ml-2 bg-myPrimaryLightGrayColor rounded-full shadow-sm"
336
+ class="pbx-min-w-[3.5rem] pbx-pt-6 pbx-pb-2 pbx-ml-2 pbx-bg-myPrimaryLightGrayColor pbx-rounded-full pbx-shadow-sm"
337
337
  >
338
- <div class="mx-2 flex flex-col myPrimaryGap items-stretch">
339
- <div class="flex gap-2 items-center justify-center">
338
+ <div class="pbx-mx-2 pbx-flex pbx-flex-col pbx-myPrimaryGap pbx-items-stretch">
339
+ <div class="pbx-flex pbx-gap-2 pbx-items-center pbx-justify-center">
340
340
  <button
341
341
  type="button"
342
342
  @click="
@@ -345,9 +345,9 @@ onMounted(async () => {
345
345
  handleAddComponent()
346
346
  }
347
347
  "
348
- class="h-10 w-10 cursor-pointer rounded-full flex items-center border-none justify-center bg-gray-50 aspect-square hover:bg-myPrimaryLinkColor hover:text-white focus-visible:ring-0"
348
+ class="pbx-h-10 pbx-w-10 pbx-cursor-pointer pbx-rounded-full pbx-flex pbx-items-center pbx-border-none pbx-justify-center pbx-bg-gray-50 pbx-aspect-square hover:pbx-bg-myPrimaryLinkColor hover:pbx-text-white focus-visible:pbx-ring-0"
349
349
  >
350
- <span class="myMediumIcon material-symbols-outlined"> interests </span>
350
+ <span class="pbx-myMediumIcon material-symbols-outlined"> interests </span>
351
351
  </button>
352
352
  </div>
353
353
  <div @click.self="pageBuilderClass.clearHtmlSelection()">
@@ -356,19 +356,19 @@ onMounted(async () => {
356
356
  </div>
357
357
  </div>
358
358
  <main
359
- class="flex flex-col h-full grow rounded-tr-2xl rounded-tl-2xl border border-gray-200 items-stretch"
360
- :class="{ 'mr-2': !getMenuRight, '': getMenuRight }"
359
+ class="pbx-flex pbx-flex-col pbx-h-full pbx-grow pbx-rounded-tr-2xl pbx-rounded-tl-2xl pbx-border pbx-border-gray-200 pbx-items-stretch"
360
+ :class="{ 'pbx-mr-2': !getMenuRight, '': getMenuRight }"
361
361
  >
362
362
  <div
363
363
  id="pagebuilder-toolbar-area"
364
- class="flex items-center justify-between rounded-t-2xl bg-myPrimaryLightGrayColor min-w-[30rem]"
364
+ class="pbx-flex pbx-items-center pbx-justify-between pbx-rounded-t-2xl pbx-bg-myPrimaryLightGrayColor pbx-min-w-[30rem]"
365
365
  >
366
366
  <div
367
367
  @click.self="pageBuilderClass.clearHtmlSelection()"
368
- class="flex myPrimaryGap items-center pt-4 pb-2 pl-2 h-24 w-full min-w-36"
368
+ class="pbx-flex pbx-myPrimaryGap pbx-items-center pbx-pt-4 pbx-pb-2 pbx-pl-2 pbx-h-24 pbx-w-full pbx-min-w-36"
369
369
  >
370
370
  <button
371
- class="mySecondaryButton h-6 flex gap-2"
371
+ class="pbx-mySecondaryButton pbx-h-6 pbx-flex pbx-gap-2"
372
372
  @click.stop="
373
373
  async () => {
374
374
  await pageBuilderClass.clearHtmlSelection()
@@ -380,19 +380,21 @@ onMounted(async () => {
380
380
  >
381
381
  <div
382
382
  v-if="!getIsSaving"
383
- class="h-10 w-4 cursor-pointer rounded-full flex items-center justify-center"
383
+ class="pbx-h-10 pbx-w-4 pbx-cursor-pointer pbx-rounded-full pbx-flex pbx-items-center pbx-justify-center"
384
384
  >
385
385
  <span class="material-symbols-outlined">save</span>
386
386
  </div>
387
387
  <div
388
388
  v-if="getIsSaving"
389
- class="h-10 w-4 cursor-pointer rounded-full flex items-center justify-center"
389
+ class="pbx-h-10 pbx-w-4 pbx-cursor-pointer pbx-rounded-full pbx-flex pbx-items-center pbx-justify-center"
390
390
  >
391
- <span class="relative flex size-3">
391
+ <span class="pbx-relative pbx-flex pbx-size-3">
392
392
  <span
393
- class="absolute inline-flex h-full w-full animate-ping rounded-full bg-gray-400 opacity-75"
393
+ class="pbx-absolute pbx-inline-flex pbx-h-full pbx-w-full pbx-animate-ping pbx-rounded-full pbx-bg-gray-400 pbx-opacity-75"
394
+ ></span>
395
+ <span
396
+ class="pbx-relative pbx-inline-flex pbx-size-3 pbx-rounded-full pbx-bg-green-200"
394
397
  ></span>
395
- <span class="relative inline-flex size-3 rounded-full bg-green-200"></span>
396
398
  </span>
397
399
  </div>
398
400
  <div>Save</div>
@@ -403,11 +405,11 @@ onMounted(async () => {
403
405
 
404
406
  <div
405
407
  @click.self="pageBuilderClass.clearHtmlSelection()"
406
- class="flex justify-end py-2 pr-2 h-24 w-full"
408
+ class="pbx-flex pbx-justify-end pbx-py-2 pbx-pr-2 pbx-h-24 pbx-w-full"
407
409
  >
408
410
  <div
409
411
  @click.self="pageBuilderClass.clearHtmlSelection()"
410
- class="flex items-center justify-center gap-4"
412
+ class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-4"
411
413
  >
412
414
  <button
413
415
  type="button"
@@ -418,18 +420,18 @@ onMounted(async () => {
418
420
  }
419
421
  "
420
422
  >
421
- <div class="flex items-center justify-center gap-2">
422
- <span class="lg:block hidden">
423
- <div class="whitespace-nowrap">Add new Components</div>
423
+ <div class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-2">
424
+ <span class="lg:pbx-block pbx-hidden">
425
+ <div class="pbx-whitespace-nowrap">Add new Components</div>
424
426
  </span>
425
427
  <span
426
- class="h-10 w-10 cursor-pointer rounded-full flex items-center border-none justify-center bg-gray-50 aspect-square hover:bg-myPrimaryLinkColor hover:text-white focus-visible:ring-0"
428
+ class="pbx-h-10 pbx-w-10 pbx-cursor-pointer pbx-rounded-full pbx-flex pbx-items-center pbx-border-none pbx-justify-center pbx-bg-gray-50 pbx-aspect-square hover:pbx-bg-myPrimaryLinkColor hover:pbx-text-white focus-visible:pbx-ring-0"
427
429
  >
428
- <span class="myMediumIcon material-symbols-outlined"> interests </span>
430
+ <span class="pbx-myMediumIcon material-symbols-outlined"> interests </span>
429
431
  </span>
430
432
  </div>
431
433
  </button>
432
- <div class="flex items-center justify-center gap-4">
434
+ <div class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-4">
433
435
  <button
434
436
  type="button"
435
437
  @click="
@@ -441,13 +443,13 @@ onMounted(async () => {
441
443
  }
442
444
  "
443
445
  >
444
- <div class="flex items-center justify-center gap-2">
445
- <div class="whitespace-nowrap lg:block hidden">Preview</div>
446
+ <div class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-2">
447
+ <div class="pbx-whitespace-nowrap lg:pbx-block pbx-hidden">Preview</div>
446
448
 
447
449
  <span
448
- class="h-10 w-10 cursor-pointer rounded-full flex items-center border-none justify-center bg-gray-50 aspect-square hover:bg-myPrimaryLinkColor hover:text-white focus-visible:ring-0"
450
+ class="pbx-h-10 pbx-w-10 pbx-cursor-pointer pbx-rounded-full pbx-flex pbx-items-center pbx-border-none pbx-justify-center pbx-bg-gray-50 pbx-aspect-square hover:pbx-bg-myPrimaryLinkColor hover:pbx-text-white focus-visible:pbx-ring-0"
449
451
  >
450
- <span class="myMediumIcon material-symbols-outlined"> visibility </span>
452
+ <span class="pbx-myMediumIcon material-symbols-outlined"> visibility </span>
451
453
  </span>
452
454
  </div>
453
455
  </button>
@@ -457,24 +459,24 @@ onMounted(async () => {
457
459
 
458
460
  <div
459
461
  @click.self="pageBuilderClass.clearHtmlSelection()"
460
- class="flex justify-end py-2 pr-2 w-full h-24"
462
+ class="pbx-flex pbx-justify-end pbx-py-2 pbx-pr-2 pbx-w-full pbx-h-24"
461
463
  >
462
464
  <div
463
465
  @click.self="pageBuilderClass.clearHtmlSelection()"
464
- class="flex items-center justify-center gap-4"
466
+ class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-4"
465
467
  >
466
468
  <button
467
469
  type="button"
468
470
  v-if="getMenuRight === false"
469
471
  @click="pageBuilderStateStore.setMenuRight(true)"
470
472
  >
471
- <div class="flex items-center justify-center gap-2">
472
- <span class="lg:block hidden"> Styling </span>
473
+ <div class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-2">
474
+ <span class="lg:pbx-block pbx-hidden"> Styling </span>
473
475
 
474
476
  <span
475
- class="h-10 w-10 cursor-pointer rounded-full flex items-center border-none justify-center bg-gray-50 aspect-square hover:bg-myPrimaryLinkColor hover:text-white focus-visible:ring-0"
477
+ class="pbx-h-10 pbx-w-10 pbx-cursor-pointer pbx-rounded-full pbx-flex pbx-items-center pbx-border-none pbx-justify-center pbx-bg-gray-50 pbx-aspect-square hover:pbx-bg-myPrimaryLinkColor hover:pbx-text-white focus-visible:pbx-ring-0"
476
478
  >
477
- <span class="myMediumIcon material-symbols-outlined"> more_vert </span>
479
+ <span class="pbx-myMediumIcon material-symbols-outlined"> more_vert </span>
478
480
  </span>
479
481
  </div>
480
482
  </button>
@@ -483,7 +485,10 @@ onMounted(async () => {
483
485
  </div>
484
486
 
485
487
  <EditGetElement></EditGetElement>
486
- <div id="contains-pagebuilder" class="pl-4 pr-4 pb-4 overflow-y-auto pt-1 h-[39rem]">
488
+ <div
489
+ id="contains-pagebuilder"
490
+ class="pbx-pl-4 pbx-pr-4 pbx-pb-4 pbx-overflow-y-auto pbx-pt-1 pbx-h-[39rem]"
491
+ >
487
492
  <div id="pagebuilder">
488
493
  <div ref="draggableZone">
489
494
  <!-- Added Components to DOM # start -->
@@ -491,9 +496,9 @@ onMounted(async () => {
491
496
  v-for="component in getComponents"
492
497
  :key="component.id"
493
498
  id="page-builder-editor-editable-area"
494
- class="bg-white grow"
499
+ class="pbx-bg-white pbx-grow"
495
500
  >
496
- <div @mouseup="handleSelectComponent(component)" class="relative group">
501
+ <div @mouseup="handleSelectComponent(component)" class="pbx-relative group">
497
502
  <div v-html="component.html_code"></div>
498
503
  </div>
499
504
  </div>
@@ -505,16 +510,16 @@ onMounted(async () => {
505
510
  <div
506
511
  @click="pageBuilderClass.clearHtmlSelection()"
507
512
  id="pagebuilder-bottom-components-area"
508
- class="pt-8 pb-12 text-center focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2 my-2 mx-4"
509
- :class="{ 'border-t border-gray-200': getComponents.length > 0 }"
513
+ class="pbx-pt-8 pbx-pb-12 pbx-text-center focus:pbx-outline-none focus:pbx-ring-2 focus:pbx-ring-indigo-500 focus:pbx-ring-offset-2 pbx-my-2 pbx-mx-4"
514
+ :class="{ 'pbx-border-t pbx-border-gray-200': getComponents.length > 0 }"
510
515
  >
511
- <div class="flex items-center justify-center gap-2 font-medium">
512
- <span class="lg:block hidden">
516
+ <div class="pbx-flex pbx-items-center pbx-justify-center pbx-gap-2 pbx-font-medium">
517
+ <span class="lg:pbx-block pbx-hidden">
513
518
  <div>Add new components to the bottom of the page</div>
514
519
  </span>
515
520
  </div>
516
521
 
517
- <div class="mt-6 flex items-center gap-2 justify-center">
522
+ <div class="pbx-mt-6 pbx-flex pbx-items-center pbx-gap-2 pbx-justify-center">
518
523
  <button
519
524
  @click="
520
525
  () => {
@@ -523,10 +528,10 @@ onMounted(async () => {
523
528
  }
524
529
  "
525
530
  type="button"
526
- class="myPrimaryButton flex items-center gap-2 justify-center"
531
+ class="pbx-myPrimaryButton pbx-flex pbx-items-center pbx-gap-2 pbx-justify-center"
527
532
  >
528
- <span class="myMediumIcon material-symbols-outlined"> interests </span>
529
- <span class="font-medium"> Add new Components </span>
533
+ <span class="pbx-myMediumIcon material-symbols-outlined"> interests </span>
534
+ <span class="pbx-font-medium"> Add new Components </span>
530
535
  </button>
531
536
  </div>
532
537
  </div>
@@ -540,10 +545,10 @@ onMounted(async () => {
540
545
  aria-label="Menu"
541
546
  id="pagebuilder-right-area"
542
547
  :class="{
543
- 'w-0': !getMenuRight,
544
- 'w-80 mr-2 bg-myPrimaryLightGrayColor items-stretch': getMenuRight,
548
+ 'pbx-w-0': !getMenuRight,
549
+ 'pbx-w-80 pbx-mr-2 pbx-bg-myPrimaryLightGrayColor pbx-items-stretch': getMenuRight,
545
550
  }"
546
- class="duration-300 z-20 flex-shrink-0 overflow-hidden shadow-sm rounded-l-2xl"
551
+ class="pbx-duration-300 pbx-z-20 pbx-flex-shrink-0 pbx-overflow-hidden pbx-shadow-sm pbx-rounded-l-2xl"
547
552
  >
548
553
  <RightSidebarEditor @closeEditor="pageBuilderStateStore.setMenuRight(false)">
549
554
  </RightSidebarEditor>
@@ -1,28 +1,10 @@
1
1
  <script setup>
2
- import { ref, computed } from 'vue'
3
- import { sharedPageBuilderStore } from '../stores/shared-store'
4
-
5
- const pageBuilderStateStore = sharedPageBuilderStore
6
-
7
- const getConfigPageBuilder = computed(() => {
8
- return pageBuilderStateStore.getConfigPageBuilder
9
- })
10
-
11
- const emit = defineEmits(['firstPageBuilderPreviewModalButton'])
12
-
13
- // first button function
14
- const firstButton = async function () {
15
- emit('firstPageBuilderPreviewModalButton')
16
- }
2
+ import { ref } from 'vue'
17
3
 
18
4
  const htmlPage = ref('')
19
5
 
20
6
  const previewData = localStorage.getItem('preview')
21
7
 
22
- // htmlPage.value = JSON.parse(htmlPage.value);
23
- // // join
24
- // htmlPage.value = htmlPage.value.join("");
25
-
26
8
  if (previewData) {
27
9
  try {
28
10
  const parsedData = JSON.parse(previewData)
@@ -38,7 +20,9 @@ if (previewData) {
38
20
 
39
21
  <template>
40
22
  <div>
41
- <div class="w-full inset-x-0 h-[90vh] bg-white overflow-x-scroll lg:pt-2 pt-2">
23
+ <div
24
+ class="pbx-w-full pbx-inset-x-0 pbx-h-[90vh] pbx-bg-white pbx-overflow-x-scroll lg:pbx-pt-2 pbx-pt-2"
25
+ >
42
26
  <div id="page-builder-editor">
43
27
  <div class="" v-html="htmlPage"></div>
44
28
  </div>