@designcrowd/fe-shared-lib 1.4.7-jj-3 → 1.4.8-promocardv0

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 (164) hide show
  1. package/dist/css/tailwind-brandCrowd.css +80 -6
  2. package/dist/css/tailwind-brandPage.css +76 -6
  3. package/dist/css/tailwind-crazyDomains.css +80 -6
  4. package/dist/css/tailwind-designCom.css +80 -6
  5. package/dist/css/tailwind-designCrowd.css +80 -6
  6. package/index.js +1 -1
  7. package/package.json +2 -1
  8. package/public/css/tailwind-brandCrowd.css +65 -0
  9. package/public/css/tailwind-brandPage.css +65 -0
  10. package/public/css/tailwind-crazyDomains.css +65 -0
  11. package/public/css/tailwind-designCom.css +65 -0
  12. package/public/css/tailwind-designCrowd.css +65 -0
  13. package/src/atoms/components/Carousel/Carousel.fixtures.js +18 -0
  14. package/src/atoms/components/Carousel/carousel.stories.js +448 -179
  15. package/src/atoms/components/PromoCard/PromoCard.stories.ts +265 -0
  16. package/src/atoms/components/PromoCard/PromoCard.vue +89 -0
  17. package/src/experiences/components/PublishBrandPageModal/PublishBrandPageModal.vue +297 -96
  18. package/tailwind.config.js +7 -8
  19. package/.storybook-static/assets/Auth-CV5AmoX8.css +0 -1
  20. package/.storybook-static/assets/Auth.stories-CX3sjxh5.js +0 -490
  21. package/.storybook-static/assets/AuthCrazyDomains.stories-Didj_VFa.js +0 -73
  22. package/.storybook-static/assets/Button-5UzSGUF6.css +0 -1
  23. package/.storybook-static/assets/Button-DtVlr_q3.js +0 -1
  24. package/.storybook-static/assets/ButtonGroup-Dfr7bNL2.css +0 -1
  25. package/.storybook-static/assets/ButtonGroup.stories-4EQk-ktb.js +0 -503
  26. package/.storybook-static/assets/ButtonPrimary-Bu6bXb_c.css +0 -1
  27. package/.storybook-static/assets/ButtonPrimary-DG9wNod9.js +0 -1
  28. package/.storybook-static/assets/Buttons.stories-B_KpeCzt.js +0 -761
  29. package/.storybook-static/assets/ButtonsCrazyDomains.stories-oZtahAmR.js +0 -199
  30. package/.storybook-static/assets/Checkbox.mixin-DkHpdvGa.js +0 -1
  31. package/.storybook-static/assets/Checkbox.stories-C67RL0ut.js +0 -203
  32. package/.storybook-static/assets/Checktile.stories-DN2wfzd6.js +0 -88
  33. package/.storybook-static/assets/CollapsiblePanel.stories-BkzrqfVG.js +0 -39
  34. package/.storybook-static/assets/ColorPicker.stories-85BQwpyF.js +0 -73
  35. package/.storybook-static/assets/CopyToClipboardText.stories-Csh5nVRs.js +0 -32
  36. package/.storybook-static/assets/Dropdown.stories-NNlxNopk.js +0 -159
  37. package/.storybook-static/assets/DropdownItem-CDX_V6Mi.js +0 -1
  38. package/.storybook-static/assets/DropdownItem-CLNmWtKh.css +0 -1
  39. package/.storybook-static/assets/FormControl.mixin-_gXRExB7.js +0 -1
  40. package/.storybook-static/assets/HashRouteModal.stories-Dy1_nLTJ.js +0 -64
  41. package/.storybook-static/assets/HelloBar-z54fob0q.js +0 -1
  42. package/.storybook-static/assets/HelloBar.stories-ClJ9_KRK.js +0 -342
  43. package/.storybook-static/assets/Icon-8mZGP41G.js +0 -144
  44. package/.storybook-static/assets/Icon.stories-BcXMvpuh.js +0 -126
  45. package/.storybook-static/assets/Icon.stories-D6ECVMta.js +0 -751
  46. package/.storybook-static/assets/Loader-D61Ki9P1.js +0 -1
  47. package/.storybook-static/assets/LogoBusinessBrandColours-B1_8hw0H.js +0 -1
  48. package/.storybook-static/assets/LogoBusinessBrandColours-DEFhAyxR.css +0 -1
  49. package/.storybook-static/assets/LogoBusinessBrandColours.stories-CIWe9ndn.js +0 -36
  50. package/.storybook-static/assets/Masonry-C2MNiGg0.css +0 -1
  51. package/.storybook-static/assets/Masonry.stories-CDT8kZCv.js +0 -71
  52. package/.storybook-static/assets/Modal-BQrpXSGA.js +0 -1
  53. package/.storybook-static/assets/Modal-BvVMN71n.css +0 -1
  54. package/.storybook-static/assets/Modal.stories-BycF7YL6.js +0 -345
  55. package/.storybook-static/assets/Notice.stories-BufkrC1b.js +0 -222
  56. package/.storybook-static/assets/NumberStepper-Blffv09R.css +0 -1
  57. package/.storybook-static/assets/NumberStepper.stories-6_y_lEgC.js +0 -64
  58. package/.storybook-static/assets/PaymentConfigList-wI1eTv5x.css +0 -1
  59. package/.storybook-static/assets/PaymentConfigList.stories-BlzzKrzz.js +0 -126
  60. package/.storybook-static/assets/Picture-Cq76CaoK.js +0 -1
  61. package/.storybook-static/assets/Picture.stories-BDqRm9_g.js +0 -119
  62. package/.storybook-static/assets/Pill-BsMeJhV9.js +0 -1
  63. package/.storybook-static/assets/Pill.stories-DUvzbtnS.js +0 -18
  64. package/.storybook-static/assets/PillBar-os4mJV3M.css +0 -1
  65. package/.storybook-static/assets/PillBar.stories-BUMLXBij.js +0 -41
  66. package/.storybook-static/assets/Price-DKOwLeD0.js +0 -1
  67. package/.storybook-static/assets/Price.stories-DlqrNUWI.js +0 -221
  68. package/.storybook-static/assets/PublishBrandPageModal-CLU8-If3.css +0 -1
  69. package/.storybook-static/assets/PublishBrandPageModal.stories-Dqobvq-n.js +0 -273
  70. package/.storybook-static/assets/SearchBar.stories-_wPX3-Rl.js +0 -12
  71. package/.storybook-static/assets/Select-Dw-zvSUg.css +0 -1
  72. package/.storybook-static/assets/Select.stories-BWINGxdY.js +0 -108
  73. package/.storybook-static/assets/SellDomainNameList.fixtures-LC6fjr_b.js +0 -1
  74. package/.storybook-static/assets/SellDomainNameListModal-ByK_ak0A.js +0 -1
  75. package/.storybook-static/assets/SellDomainNameListModal-CdfyEX1a.css +0 -1
  76. package/.storybook-static/assets/SellDomainNameListModal.stories-DrL8w2AY.js +0 -71
  77. package/.storybook-static/assets/SellDomainNameListSearchResult-1WuAKfzI.css +0 -1
  78. package/.storybook-static/assets/SellDomainNameListSearchResult-By0IpIM_.js +0 -1
  79. package/.storybook-static/assets/SellDomainNameSearchWithResults-BttjI4PH.js +0 -1
  80. package/.storybook-static/assets/SellDomainNameSearchWithResults.stories-Dm1Q8Cza.js +0 -37
  81. package/.storybook-static/assets/SellDomainNameWidget.stories-CKoz3WnZ.js +0 -36
  82. package/.storybook-static/assets/SignIn-DNYeJu86.css +0 -1
  83. package/.storybook-static/assets/SignIn-Dt8OJr0J.js +0 -1
  84. package/.storybook-static/assets/Slider-Cog2FFdj.css +0 -1
  85. package/.storybook-static/assets/Slider.stories-08DN2SFB.js +0 -141
  86. package/.storybook-static/assets/StarRating-BtKh7pzm.css +0 -1
  87. package/.storybook-static/assets/StarRating.stories-BEIj9ufA.js +0 -45
  88. package/.storybook-static/assets/TabMenu.stories-D9f0pyZI.js +0 -47
  89. package/.storybook-static/assets/TextCopyField-B04vTGbG.js +0 -1
  90. package/.storybook-static/assets/TextCopyField.stories-KD0WUWzA.js +0 -47
  91. package/.storybook-static/assets/TextInput-JK1M0hv6.js +0 -1
  92. package/.storybook-static/assets/TextInput.stories-BO0eQqBY.js +0 -233
  93. package/.storybook-static/assets/Textarea.stories-Bcn4sCkV.js +0 -207
  94. package/.storybook-static/assets/Toggle.stories-CuTFLoNh.js +0 -161
  95. package/.storybook-static/assets/Tooltip-DcSbUh5f.js +0 -1
  96. package/.storybook-static/assets/Tooltip-DyXIgFQH.css +0 -1
  97. package/.storybook-static/assets/Tooltip.stories-B0I_PBGG.js +0 -953
  98. package/.storybook-static/assets/UploadYourLogoApplication-EyTEQx-x.css +0 -9
  99. package/.storybook-static/assets/UploadYourLogoApplication.stories-Dixp1ynI.js +0 -194
  100. package/.storybook-static/assets/UploadYourLogoDropzone-DQqACf-e.css +0 -1
  101. package/.storybook-static/assets/UploadYourLogoDropzone-DouZtNvi.js +0 -24
  102. package/.storybook-static/assets/UploadYourLogoDropzone.stories-BHYeu4gz.js +0 -55
  103. package/.storybook-static/assets/UploadedLogoSearchResultCard.stories-D1KR63O4.js +0 -79
  104. package/.storybook-static/assets/_commonjsHelpers-D6-XlEtG.js +0 -1
  105. package/.storybook-static/assets/_plugin-vue_export-helper-DlAUqK2U.js +0 -1
  106. package/.storybook-static/assets/api-lSJGRrF2.js +0 -1
  107. package/.storybook-static/assets/axe-nGVJxRof.js +0 -30
  108. package/.storybook-static/assets/brand-crowd-api.client-DiPM1Wo-.js +0 -1
  109. package/.storybook-static/assets/bundled-translations-BZ57czTo.js +0 -1
  110. package/.storybook-static/assets/bundled-translations.de-DE-DXggTXB2.js +0 -1
  111. package/.storybook-static/assets/bundled-translations.es-ES-DtMmvicd.js +0 -1
  112. package/.storybook-static/assets/bundled-translations.fr-FR-BrQqbieG.js +0 -1
  113. package/.storybook-static/assets/bundled-translations.pt-PT-CpiWEAtr.js +0 -1
  114. package/.storybook-static/assets/carousel-CMMZ5MZ-.css +0 -1
  115. package/.storybook-static/assets/carousel.stories-o3eu2Qyc.js +0 -374
  116. package/.storybook-static/assets/event-constants-CMO9VQVu.js +0 -1
  117. package/.storybook-static/assets/iframe-C86bI_2U.js +0 -1126
  118. package/.storybook-static/assets/index-Bw-gCGc_.js +0 -6
  119. package/.storybook-static/assets/index-DhkYCT1V.js +0 -29
  120. package/.storybook-static/assets/matchers-7Z3WT2CE-T3xScrR7.js +0 -14
  121. package/.storybook-static/assets/tracking-ATsLLehC.js +0 -1
  122. package/.storybook-static/css/tailwind-brandCrowd.css +0 -2404
  123. package/.storybook-static/css/tailwind-brandPage.css +0 -2088
  124. package/.storybook-static/css/tailwind-crazyDomains.css +0 -2404
  125. package/.storybook-static/css/tailwind-designCom.css +0 -2404
  126. package/.storybook-static/css/tailwind-designCrowd.css +0 -2404
  127. package/.storybook-static/favicon.svg +0 -1
  128. package/.storybook-static/iframe.html +0 -694
  129. package/.storybook-static/index.html +0 -156
  130. package/.storybook-static/index.json +0 -1
  131. package/.storybook-static/nunito-sans-bold-italic.woff2 +0 -0
  132. package/.storybook-static/nunito-sans-bold.woff2 +0 -0
  133. package/.storybook-static/nunito-sans-italic.woff2 +0 -0
  134. package/.storybook-static/nunito-sans-regular.woff2 +0 -0
  135. package/.storybook-static/project.json +0 -1
  136. package/.storybook-static/sb-addons/a11y-1/manager-bundle.js +0 -5
  137. package/.storybook-static/sb-addons/links-2/manager-bundle.js +0 -3
  138. package/.storybook-static/sb-addons/storybook-core-server-presets-0/common-manager-bundle.js +0 -188
  139. package/.storybook-static/sb-addons/themes-3/manager-bundle.js +0 -3
  140. package/.storybook-static/sb-common-assets/favicon.svg +0 -1
  141. package/.storybook-static/sb-common-assets/nunito-sans-bold-italic.woff2 +0 -0
  142. package/.storybook-static/sb-common-assets/nunito-sans-bold.woff2 +0 -0
  143. package/.storybook-static/sb-common-assets/nunito-sans-italic.woff2 +0 -0
  144. package/.storybook-static/sb-common-assets/nunito-sans-regular.woff2 +0 -0
  145. package/.storybook-static/sb-manager/globals-module-info.js +0 -797
  146. package/.storybook-static/sb-manager/globals-runtime.js +0 -72062
  147. package/.storybook-static/sb-manager/globals.js +0 -34
  148. package/.storybook-static/sb-manager/runtime.js +0 -13002
  149. package/src/atoms/components/SparkleIcon/SparkleIcon.stories.js +0 -182
  150. package/src/atoms/components/SparkleIcon/SparkleIcon.vue +0 -105
  151. package/src/atoms/components/SparkleIcon/assets/animations/state-01.svg +0 -5
  152. package/src/atoms/components/SparkleIcon/assets/animations/state-02.svg +0 -5
  153. package/src/atoms/components/SparkleIcon/assets/animations/state-03.svg +0 -5
  154. package/src/atoms/components/SparkleIcon/assets/animations/state-04.svg +0 -5
  155. package/src/atoms/components/SparkleIcon/assets/animations/state-05.svg +0 -5
  156. package/src/atoms/components/SparkleIcon/assets/animations/state-06.svg +0 -5
  157. package/src/atoms/components/SparkleIcon/assets/animations/state-07.svg +0 -5
  158. package/src/atoms/components/SparkleIcon/assets/animations/state-08.svg +0 -5
  159. package/src/atoms/components/SparkleIcon/assets/sparkle.svg +0 -3
  160. package/src/atoms/components/SparkleIcon/index.ts +0 -3
  161. package/src/experiences/components/PublishBrandPageModal/views/PublishWhenHasDomainsView.vue +0 -271
  162. package/src/experiences/components/PublishBrandPageModal/views/PublishWhenNoDomainsView.vue +0 -168
  163. package/src/experiences/components/PublishBrandPageModal/views/PublishedView.vue +0 -149
  164. package/src/experiences/components/PublishBrandPageModal/views/SetUrlView.vue +0 -155
@@ -1,168 +0,0 @@
1
- <template>
2
- <div>
3
- <div class="tw-mt-4">
4
- <PublishBrandPageCard
5
- :img-url="iconUrl"
6
- :title="freePublishCardTitleLabel"
7
- :description="freePublishCardDescriptionLabel"
8
- :is-design-com="isDesignCom"
9
- :has-search-button="false"
10
- >
11
- <template #slug>
12
- <div class="tw-flex tw-flex-col md:tw-flex-row tw-justify-between">
13
- <div class="tw-grow md:tw-mr-2">
14
- <TextInput
15
- v-model="internalSlug"
16
- element-classes="tw-mb-0 !tw-rounded-l-none tw-text-md"
17
- :prefix-text="`${brandPageBaseUrlWithoutHttps}/`"
18
- :error="!!slugValidationError"
19
- :disabled="isInputEnabled"
20
- :placeholder="getPlaceHolder"
21
- data-test-brand-page-slug-input
22
- :attrs="{ 'data-test-set-url-text-field': '' }"
23
- @input="onSlugChanged"
24
- />
25
- <div v-if="slugErrorMessage" class="tw-mt-2 tw-text-sm tw-text-left tw-text-error-500 tw-font-normal">
26
- {{ slugErrorMessage }}
27
- </div>
28
- </div>
29
- <Button
30
- :label="publishLabel"
31
- :disabled="isPublishingDisabled"
32
- class="tw-flex tw-items-center tw-justify-center tw-mt-2 md:tw-mt-0 tw-font-bold tw-transition-colors tw-duration-300"
33
- data-test-brand-page-publish-button
34
- variant="primary"
35
- size="small-medium"
36
- :full-width="isMobile"
37
- :class="{
38
- 'tw-uppercase': !isDesignCom,
39
- }"
40
- @on-click="onPublish"
41
- />
42
- </div>
43
- </template>
44
- </PublishBrandPageCard>
45
- </div>
46
- <div class="tw-mt-4">
47
- <slot name="recommended" />
48
- </div>
49
- </div>
50
- </template>
51
- <script>
52
- import PublishBrandPageCard from '../PublishBrandPageCard.vue';
53
- import TextInput from '../../../../atoms/components/TextInput/TextInput.vue';
54
- import Button from '../../../../atoms/components/Button/Button.vue';
55
- import mediaQueryMixin from '../../../mixins/mediaQueryMixin';
56
- import { publishBrandPageModalTr } from '../../../../useSharedLibTranslate';
57
-
58
- const DCOM_IMG_FREE = 'https://brandcrowd-cdn.s3.amazonaws.com/public/assets/images/icons/publish/dcom-free-url.svg';
59
- const BC_IMG_FREE = 'https://brandcrowd-cdn.s3.amazonaws.com/public/assets/images/icons/publish/bc-free-url.svg';
60
-
61
- export default {
62
- components: {
63
- TextInput,
64
- Button,
65
- PublishBrandPageCard,
66
- },
67
- mixins: [mediaQueryMixin],
68
- props: {
69
- brandPageBaseUrl: {
70
- type: String,
71
- required: true,
72
- default: undefined,
73
- },
74
- brandPageSlug: {
75
- type: String,
76
- required: true,
77
- default: undefined,
78
- },
79
- slugValidationError: {
80
- type: String,
81
- required: true,
82
- default: undefined,
83
- },
84
- errorMessage: {
85
- type: String,
86
- required: false,
87
- default: undefined,
88
- },
89
- publishErrorMessage: {
90
- type: String,
91
- required: false,
92
- default: undefined,
93
- },
94
- isPublishing: {
95
- type: Boolean,
96
- required: true,
97
- default: false,
98
- },
99
- isDesignCom: {
100
- type: Boolean,
101
- required: true,
102
- default: false,
103
- },
104
- brandPageType: {
105
- type: String,
106
- required: true,
107
- default: '',
108
- },
109
- },
110
- emits: ['internal-publish-brand-page', 'on-slug-changed'],
111
- setup() {
112
- return {
113
- publishBrandPageModalTr,
114
- freePublishCardTitleLabel: publishBrandPageModalTr('freePublishCardTitleLabel'),
115
- freePublishCardDescriptionLabel: publishBrandPageModalTr('freePublishCardDescriptionLabel'),
116
- slugInputPlaceholderYourNameLabel: publishBrandPageModalTr('slugInputPlaceholderYourNameLabel'),
117
- slugInputPlaceholderYourBusinessNameLabel: publishBrandPageModalTr('slugInputPlaceholderYourBusinessNameLabel'),
118
- publishLabel: publishBrandPageModalTr('publishLabel'),
119
- };
120
- },
121
- data() {
122
- return {
123
- internalSlug: this.brandPageSlug,
124
- };
125
- },
126
- computed: {
127
- brandPageBaseUrlWithoutHttps() {
128
- return this.brandPageBaseUrl.replace('https://', '');
129
- },
130
- allowPublish() {
131
- return this.internalSlug && !this.slugValidationError;
132
- },
133
- slugErrorMessage() {
134
- return this.slugValidationError ? this.slugValidationError : this.publishErrorMessage;
135
- },
136
- iconUrl() {
137
- return this.isDesignCom ? DCOM_IMG_FREE : BC_IMG_FREE;
138
- },
139
- isInputEnabled() {
140
- return this.isPublishing;
141
- },
142
- isPublishingDisabled() {
143
- return !this.allowPublish || this.isPublishing;
144
- },
145
- getPlaceHolder() {
146
- return this.brandPageType === 'brandContact'
147
- ? this.slugInputPlaceholderYourNameLabel
148
- : this.slugInputPlaceholderYourBusinessNameLabel;
149
- },
150
- },
151
- watch: {
152
- brandPageSlug(slug) {
153
- this.internalSlug = slug;
154
- },
155
- },
156
- mounted() {
157
- this.internalSlug = this.brandPageSlug;
158
- },
159
- methods: {
160
- onSlugChanged(e) {
161
- this.$emit('on-slug-changed', e);
162
- },
163
- onPublish() {
164
- this.$emit('internal-publish-brand-page', this.internalSlug);
165
- },
166
- },
167
- };
168
- </script>
@@ -1,149 +0,0 @@
1
- <template>
2
- <div class="tw-font-sans">
3
- <div v-if="!showUpsellRotationContainer" class="tw-mb-6 tw-text-left">
4
- <div class="tw-mb-6">
5
- <SellDomainNameSearchWithResults
6
- :is-design-com="isDesignCom"
7
- :initial-search-term="searchText"
8
- :currency="userCurrency"
9
- :display-result-limit="4"
10
- :domain-search-location="sitePublishedModal"
11
- show-view-more-button
12
- @on-change-search="onSearchTextChanged"
13
- @on-buy-now-click="onBuyNowClick"
14
- @on-view-more="onViewMore"
15
- />
16
- </div>
17
- </div>
18
- <div class="tw-px-4 tw-text-center" :class="{ 'lg:tw-px-20': hasPurchasedDomains }">
19
- <TextCopyField
20
- button-variant="secondary"
21
- :text="brandPageUrl"
22
- :default-copy-button-text="copyLabel"
23
- :copied-button-text="copySuccessLabel"
24
- data-test-brand-page-copy-input
25
- @on-click="onCopyUrlClick"
26
- />
27
- <Button
28
- :label="viewMyWebsiteLabel"
29
- :variant="isDesignCom ? 'primary' : 'primary-with-icon'"
30
- icon="chevron-right-wide"
31
- size="medium"
32
- icon-view-box="0 0 24 24"
33
- class="tw-my-4"
34
- target="_blank"
35
- rel="noopener noreferrer"
36
- :url="brandPageUrl"
37
- :full-width="isMobile"
38
- @on-click="onBrandPageUrlClick"
39
- />
40
- </div>
41
- <div v-if="showUpsellRotationContainer" class="tw-border-t tw-border-solid tw-border-grayscale-500 tw-p-5">
42
- <slot name="upsellContainer" />
43
- </div>
44
- </div>
45
- </template>
46
- <script>
47
- import Button from '../../../../atoms/components/Button/Button.vue';
48
- import TextCopyField from '../../../../atoms/components/TextCopyField/TextCopyField.vue';
49
-
50
- import SellDomainNameSearchWithResults from '../../SellDomainNameSearchWithResults/SellDomainNameSearchWithResults.vue';
51
- import { sitePublishedModal } from '../../../constants/event-constants';
52
- import mediaQueryMixin from '../../../mixins/mediaQueryMixin';
53
- import { publishBrandPageModalTr } from '../../../../useSharedLibTranslate';
54
-
55
- export default {
56
- components: {
57
- Button,
58
- TextCopyField,
59
- SellDomainNameSearchWithResults,
60
- },
61
- mixins: [mediaQueryMixin],
62
- props: {
63
- brandPageUrl: {
64
- type: String,
65
- required: true,
66
- default: undefined,
67
- },
68
- isDesignCom: {
69
- type: Boolean,
70
- required: true,
71
- default: false,
72
- },
73
- showUpsellRotation: {
74
- type: Boolean,
75
- required: true,
76
- default: false,
77
- },
78
- isSubsequentPublish: {
79
- type: Boolean,
80
- required: true,
81
- default: false,
82
- },
83
- searchText: {
84
- type: String,
85
- required: false,
86
- default: '',
87
- },
88
- brandPageDisplayName: {
89
- type: String,
90
- required: true,
91
- default: undefined,
92
- },
93
- hasPurchasedDomains: {
94
- type: Boolean,
95
- required: true,
96
- default: false,
97
- },
98
- showUpsellRotationContainer: {
99
- type: Boolean,
100
- required: true,
101
- default: false,
102
- },
103
- userCurrency: {
104
- type: String,
105
- required: true,
106
- default: undefined,
107
- },
108
- },
109
- emits: [
110
- 'copy-url-clicked',
111
- 'on-brand-page-url-click',
112
- 'on-view-more-domains',
113
- 'on-buy-now-clicked',
114
- 'on-search-text-changed',
115
- ],
116
- setup() {
117
- return {
118
- sitePublishedModal,
119
- publishBrandPageModalTr,
120
- copyLabel: publishBrandPageModalTr('copyLabel'),
121
- copySuccessLabel: publishBrandPageModalTr('copySuccessLabel'),
122
- };
123
- },
124
- computed: {
125
- viewMyWebsiteLabel() {
126
- return this.publishBrandPageModalTr('viewMyWebsiteLabel', {
127
- brandPageDisplayName: this.brandPageDisplayName,
128
- });
129
- },
130
- },
131
- methods: {
132
- onCopyUrlClick() {
133
- this.$emit('copy-url-clicked');
134
- },
135
- onBrandPageUrlClick() {
136
- this.$emit('on-brand-page-url-click');
137
- },
138
- onViewMore() {
139
- this.$emit('on-view-more-domains');
140
- },
141
- onSearchTextChanged(val) {
142
- this.$emit('on-search-text-changed', val);
143
- },
144
- onBuyNowClick() {
145
- this.$emit('on-buy-now-clicked');
146
- },
147
- },
148
- };
149
- </script>
@@ -1,155 +0,0 @@
1
- <template>
2
- <div>
3
- <div class="tw-mt-4">
4
- <div>
5
- <TextInput
6
- v-model="internalSlug"
7
- element-classes="tw-mb-0 !tw-rounded-l-none tw-text-lg"
8
- :prefix-text="`${brandPageBaseUrlWithoutHttps}/`"
9
- :error="!!slugValidationError"
10
- :disabled="isInputEnabled"
11
- :placeholder="getPlaceHolder"
12
- data-test-brand-page-slug-input
13
- :attrs="{ 'data-test-set-url-text-field': '' }"
14
- @input="onSlugChanged"
15
- />
16
- <div v-if="slugErrorMessage" class="tw-mt-2 tw-text-sm tw-text-left tw-text-error-500 tw-font-normal">
17
- {{ slugErrorMessage }}
18
- </div>
19
- </div>
20
- </div>
21
- <div class="tw-font-sans tw-text-center" :style="isMobile ? 'padding-left: 1.5rem; padding-right: 1.5rem;' : ''">
22
- <Button
23
- :label="setUrlLabel"
24
- :variant="isDesignCom ? 'primary' : 'primary-with-icon'"
25
- icon="chevron-right-wide"
26
- :disabled="isPublishingDisabled"
27
- class="tw-my-4"
28
- :full-width="isMobile"
29
- data-test-brand-page-publish-button
30
- @on-click="onPublish"
31
- />
32
- <Button
33
- :label="hasAlreadyPurchasedDomainCloseButtonLabel"
34
- variant="no-border"
35
- size="large"
36
- class="tw-my-4"
37
- :full-width="isMobile"
38
- @on-click="onCloseModal"
39
- />
40
- </div>
41
- </div>
42
- </template>
43
- <script>
44
- import TextInput from '../../../../atoms/components/TextInput/TextInput.vue';
45
- import Button from '../../../../atoms/components/Button/Button.vue';
46
- import mediaQueryMixin from '../../../mixins/mediaQueryMixin';
47
- import { publishBrandPageModalTr } from '../../../../useSharedLibTranslate';
48
-
49
- export default {
50
- components: {
51
- TextInput,
52
- Button,
53
- },
54
- mixins: [mediaQueryMixin],
55
- props: {
56
- brandPageBaseUrl: {
57
- type: String,
58
- required: true,
59
- default: undefined,
60
- },
61
- brandPageSlug: {
62
- type: String,
63
- required: true,
64
- default: undefined,
65
- },
66
- slugValidationError: {
67
- type: String,
68
- required: true,
69
- default: undefined,
70
- },
71
- errorMessage: {
72
- type: String,
73
- required: false,
74
- default: undefined,
75
- },
76
- publishErrorMessage: {
77
- type: String,
78
- required: false,
79
- default: undefined,
80
- },
81
- isPublishing: {
82
- type: Boolean,
83
- required: true,
84
- default: false,
85
- },
86
- isDesignCom: {
87
- type: Boolean,
88
- required: true,
89
- default: false,
90
- },
91
- brandPageType: {
92
- type: String,
93
- required: true,
94
- default: '',
95
- },
96
- },
97
- emits: ['close-modal', 'internal-publish-brand-page', 'on-slug-changed'],
98
- setup() {
99
- return {
100
- publishBrandPageModalTr,
101
- slugInputPlaceholderYourNameLabel: publishBrandPageModalTr('slugInputPlaceholderYourNameLabel'),
102
- slugInputPlaceholderYourBusinessNameLabel: publishBrandPageModalTr('slugInputPlaceholderYourBusinessNameLabel'),
103
- setUrlLabel: publishBrandPageModalTr('setUrlLabel'),
104
- hasAlreadyPurchasedDomainCloseButtonLabel: publishBrandPageModalTr('hasAlreadyPurchasedDomainCloseButtonLabel'),
105
- };
106
- },
107
- data() {
108
- return {
109
- domainTypeValue: this.radioValue,
110
- internalSlug: this.brandPageSlug,
111
- };
112
- },
113
- computed: {
114
- brandPageBaseUrlWithoutHttps() {
115
- return this.brandPageBaseUrl.replace('https://', '');
116
- },
117
- allowPublish() {
118
- return this.internalSlug && !this.slugValidationError;
119
- },
120
- slugErrorMessage() {
121
- return this.slugValidationError ? this.slugValidationError : this.publishErrorMessage;
122
- },
123
- isInputEnabled() {
124
- return this.isPublishing;
125
- },
126
- isPublishingDisabled() {
127
- return !this.allowPublish || this.isPublishing;
128
- },
129
- getPlaceHolder() {
130
- return this.brandPageType === 'brandContact'
131
- ? this.slugInputPlaceholderYourNameLabel
132
- : this.slugInputPlaceholderYourBusinessNameLabel;
133
- },
134
- },
135
- watch: {
136
- brandPageSlug(slug) {
137
- this.internalSlug = slug;
138
- },
139
- },
140
- mounted() {
141
- this.internalSlug = this.brandPageSlug;
142
- },
143
- methods: {
144
- onCloseModal() {
145
- this.$emit('close-modal');
146
- },
147
- onSlugChanged(e) {
148
- this.$emit('on-slug-changed', e);
149
- },
150
- onPublish() {
151
- this.$emit('internal-publish-brand-page', this.internalSlug, undefined);
152
- },
153
- },
154
- };
155
- </script>