@kompasid/lit-web-components 0.3.1 → 0.4.1

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 (70) hide show
  1. package/assets/video.jpg +0 -0
  2. package/demo/index.html +38 -37
  3. package/dist/src/components/{kompas-footer → kompasid-footer}/KompasFooter.js +16 -4
  4. package/dist/src/components/kompasid-footer/KompasFooter.js.map +1 -0
  5. package/dist/src/components/kompasid-footer/types.js.map +1 -0
  6. package/dist/src/components/{kompas-metered-paywall → kompasid-metered-paywall}/KompasMeteredPaywall.js +3 -3
  7. package/dist/src/components/kompasid-metered-paywall/KompasMeteredPaywall.js.map +1 -0
  8. package/dist/src/components/{kompas-paywall → kompasid-paywall}/KompasPaywall.d.ts +3 -3
  9. package/dist/src/components/{kompas-paywall → kompasid-paywall}/KompasPaywall.js +17 -20
  10. package/dist/src/components/kompasid-paywall/KompasPaywall.js.map +1 -0
  11. package/dist/src/components/kompasid-paywall/types.js.map +1 -0
  12. package/dist/src/components/{kompas-paywall-banner-registration → kompasid-paywall-banner-registration}/KompasPaywallBannerRegistration.d.ts +1 -1
  13. package/dist/src/components/{kompas-paywall-banner-registration → kompasid-paywall-banner-registration}/KompasPaywallBannerRegistration.js +1 -1
  14. package/dist/src/components/kompasid-paywall-banner-registration/KompasPaywallBannerRegistration.js.map +1 -0
  15. package/dist/src/components/{kompas-paywall-body → kompasid-paywall-body}/KompasPaywallBody.d.ts +36 -9
  16. package/dist/src/components/{kompas-paywall-body → kompasid-paywall-body}/KompasPaywallBody.js +405 -288
  17. package/dist/src/components/kompasid-paywall-body/KompasPaywallBody.js.map +1 -0
  18. package/dist/src/components/{kompas-paywall-information-header → kompasid-paywall-information-header}/KompasPaywallInformationHeader.js +1 -1
  19. package/dist/src/components/kompasid-paywall-information-header/KompasPaywallInformationHeader.js.map +1 -0
  20. package/dist/src/components/{kompas-paywall-video → kompasid-paywall-video}/KompasPaywallVideo.d.ts +41 -5
  21. package/dist/src/components/kompasid-paywall-video/KompasPaywallVideo.js +302 -0
  22. package/dist/src/components/kompasid-paywall-video/KompasPaywallVideo.js.map +1 -0
  23. package/dist/src/index.d.ts +4 -4
  24. package/dist/src/index.js +4 -4
  25. package/dist/src/index.js.map +1 -1
  26. package/dist/src/utils/formatRupiah.d.ts +1 -0
  27. package/dist/src/utils/formatRupiah.js +7 -0
  28. package/dist/src/utils/formatRupiah.js.map +1 -0
  29. package/dist/tailwind/tailwind.js +123 -95
  30. package/dist/tailwind/tailwind.js.map +1 -1
  31. package/dist/tsconfig.tsbuildinfo +1 -1
  32. package/package.json +1 -1
  33. package/src/components/{kompas-footer → kompasid-footer}/KompasFooter.ts +16 -4
  34. package/src/components/{kompas-metered-paywall → kompasid-metered-paywall}/KompasMeteredPaywall.ts +3 -3
  35. package/src/components/{kompas-metered-paywall → kompasid-metered-paywall}/readme.md +1 -1
  36. package/src/components/{kompas-paywall → kompasid-paywall}/KompasPaywall.ts +17 -20
  37. package/src/components/{kompas-paywall → kompasid-paywall}/readme.md +8 -8
  38. package/src/components/{kompas-paywall-banner-registration → kompasid-paywall-banner-registration}/KompasPaywallBannerRegistration.ts +2 -2
  39. package/src/components/{kompas-paywall-banner-registration → kompasid-paywall-banner-registration}/readme.md +4 -4
  40. package/src/components/{kompas-paywall-body → kompasid-paywall-body}/KompasPaywallBody.ts +345 -197
  41. package/src/components/{kompas-paywall-body → kompasid-paywall-body}/readme.md +4 -4
  42. package/src/components/{kompas-paywall-information-header → kompasid-paywall-information-header}/KompasPaywallInformationHeader.ts +1 -1
  43. package/src/components/{kompas-paywall-information-header → kompasid-paywall-information-header}/readme.md +4 -4
  44. package/src/components/kompasid-paywall-video/KompasPaywallVideo.ts +269 -0
  45. package/src/components/{kompas-paywall-video → kompasid-paywall-video}/readme.md +4 -3
  46. package/src/index.ts +4 -4
  47. package/src/utils/formatRupiah.ts +6 -0
  48. package/tailwind/tailwind.css +120 -92
  49. package/tailwind/tailwind.ts +123 -95
  50. package/tailwind.config.js +3 -1
  51. package/dist/src/components/kompas-footer/KompasFooter.js.map +0 -1
  52. package/dist/src/components/kompas-footer/types.js.map +0 -1
  53. package/dist/src/components/kompas-metered-paywall/KompasMeteredPaywall.js.map +0 -1
  54. package/dist/src/components/kompas-paywall/KompasPaywall.js.map +0 -1
  55. package/dist/src/components/kompas-paywall/types.js.map +0 -1
  56. package/dist/src/components/kompas-paywall-banner-registration/KompasPaywallBannerRegistration.js.map +0 -1
  57. package/dist/src/components/kompas-paywall-body/KompasPaywallBody.js.map +0 -1
  58. package/dist/src/components/kompas-paywall-information-header/KompasPaywallInformationHeader.js.map +0 -1
  59. package/dist/src/components/kompas-paywall-video/KompasPaywallVideo.js +0 -240
  60. package/dist/src/components/kompas-paywall-video/KompasPaywallVideo.js.map +0 -1
  61. package/src/components/kompas-paywall-video/KompasPaywallVideo.ts +0 -195
  62. /package/dist/src/components/{kompas-footer → kompasid-footer}/KompasFooter.d.ts +0 -0
  63. /package/dist/src/components/{kompas-footer → kompasid-footer}/types.d.ts +0 -0
  64. /package/dist/src/components/{kompas-footer → kompasid-footer}/types.js +0 -0
  65. /package/dist/src/components/{kompas-metered-paywall → kompasid-metered-paywall}/KompasMeteredPaywall.d.ts +0 -0
  66. /package/dist/src/components/{kompas-paywall → kompasid-paywall}/types.d.ts +0 -0
  67. /package/dist/src/components/{kompas-paywall → kompasid-paywall}/types.js +0 -0
  68. /package/dist/src/components/{kompas-paywall-information-header → kompasid-paywall-information-header}/KompasPaywallInformationHeader.d.ts +0 -0
  69. /package/src/components/{kompas-footer → kompasid-footer}/types.ts +0 -0
  70. /package/src/components/{kompas-paywall → kompasid-paywall}/types.ts +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"file":"KompasPaywallBody.js","sourceRoot":"","sources":["../../../../src/components/kompas-paywall-body/KompasPaywallBody.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-return-assign */\n\nimport { html, css, LitElement } from 'lit'\nimport { property, state, customElement } from 'lit/decorators.js'\nimport { unsafeSVG } from 'lit/directives/unsafe-svg.js'\nimport { TWStyles } from '../../../tailwind/tailwind.js'\nimport {\n PaywallProduct,\n Product,\n Packages,\n PaymentImage,\n} from '../kompas-paywall/types.js'\nimport { getFontAwesomeIcon } from '../../utils/fontawesome-setup.js'\nimport { deviceType } from '../../utils/deviceType.js'\n\n@customElement('kompas-paywall-body')\nexport class KompasPaywallBody extends LitElement {\n static styles = [\n css`\n .wrapper-body {\n display: flex;\n flex-direction: column;\n justify-items: center;\n align-items: center;\n }\n `,\n TWStyles,\n ]\n\n /**\n * Props\n */\n /**\n * prop slug untuk menghandle slug\n * prop isLogin untuk menghandle apakah user sudah login atau belum\n * prop type untuk menghandle tipe epaper\n * prop paywallData untuk menghandle data paywall\n * prop userGuid untuk menghandle user Guid\n * prop subscriptionStatus untuk menghandle status subscription user\n * prop countdownArticle untuk menghandle count artikel\n * prop swgEnable untuk menghandle swg apakah di aktifkan atau tidak\n * prop paywall_location = The location where user encounter the paywall\n * prop paywall_subscription_package = The name of the subscription package viewed by user\n * prop paywall_subscription_id = The ID of the subscription package viewed by user\n * prop paywall_subscription_price = The price of the subscriprtion package viewed by user\n * prop paywall_position = The position of the subscription package viewed by user\n * prop tracker_page_type = Type of the page\n * prop tracker_content_id = ID of article (slug)\n * prop tracker_content_type = Whether it's free article or paid article\n * prop tracker_content_title = The title of article\n * prop tracker_content_categories = The category of the content\n * prop tracker_user_type = Type of user based on their subscription\n * prop tracker_subscription_status = Status of their subscription\n * prop tracker_page_domain = Page Domain\n * prop tracker_metered_wall_type = The type of Metered Wall\n * prop tracker_metered_wall_balance = The balance of their metered wall\n * prop tracker_metered_wall_balance = The edition of epaper viewed by user\n * prop theme = The theme of the paywall component\n */\n\n @property({ type: String }) slug = ''\n @property({ type: Number }) udin = 0\n @property({ type: Boolean }) isLogin = false\n @property({ type: String }) type: 'epaper' | 'reguler' = 'reguler'\n @property({ type: Object }) paywallData: PaywallProduct | undefined =\n undefined\n @property({ type: String }) userGuid = ''\n @property({ type: String }) subscriptionStatus = ''\n @property({ type: Number }) countdownArticle = 0\n @property({ type: Boolean }) swgEnable = false\n @property({ type: String }) paywall_location = ''\n @property({ type: String }) paywall_subscription_package = ''\n @property({ type: Number }) paywall_subscription_id = 0\n @property({ type: Number }) paywall_subscription_price = 0\n @property({ type: Number }) paywall_position = 0\n @property({ type: String }) tracker_page_type = ''\n @property({ type: String }) tracker_content_id = ''\n @property({ type: String }) tracker_content_title = ''\n @property({ type: String }) tracker_content_categories = ''\n @property({ type: String }) tracker_content_type = ''\n @property({ type: String }) tracker_user_type = ''\n @property({ type: String }) tracker_subscription_status = ''\n @property({ type: String }) tracker_page_domain = ''\n @property({ type: String }) tracker_metered_wall_type = ''\n @property({ type: Number }) tracker_metered_wall_balance = 0\n @property({ type: String }) tracker_epaper_edition = ''\n @property({ type: String }) theme = ''\n\n @state() private isExtensionsOpened = false\n @state() private kompasAkunHost = 'https://akun.kompas.id'\n @state() private kompasApigenHost = 'https://apigen.kompas.id'\n @state() private kompasApiWcmHost = 'https://apiwcm.kompas.id'\n @state() private kompasLoginHost = 'https://account.kompas.id/login'\n @state() private selfHost = 'https://epaper.kompas.id'\n @state() private swgPublisherName = 'Harian Kompas'\n @state() private swgPublisherId = 'kompas.id'\n @state() private swgProductId = 'kompas.id:kompas_digital_premium'\n @state() private errorFlag = 0\n\n buttonElement!: HTMLButtonElement\n\n private getRupiahFormat(value: number) {\n const roundedValue = Math.round(value)\n return `Rp ${roundedValue\n .toString()\n .replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1.')}`\n }\n\n private redirectToCheckout(\n url: string,\n name: string,\n id: string,\n price: number,\n position: number\n ): void {\n this.sendDataLayeronButtonBuyPackage(name, id, price, position)\n const originHost: string = encodeURIComponent(window.location.href)\n const source: string = this.type === 'epaper' ? 'epaper' : ''\n const directUrlCheckout: string = `${url}${originHost}&source=${source}`\n window.open(directUrlCheckout)\n }\n\n private redirectToPrevUrl(): void {\n window.history.back()\n }\n\n private redirectToSubscriber(): void {\n this.sendDataLayer()\n window.open('https://www.kompas.id/berlangganan')\n }\n\n private redirectToRegister(): void {\n const loginHost: string = 'https://account.kompas.id/login'\n const nextParams: string = encodeURIComponent(window.location.href)\n const directUrlRegister: string = `${loginHost}?next=${nextParams}?status=sukses_login&status_login=login`\n window.location.href = directUrlRegister\n }\n\n private redirectToHelpdesk(): void {\n this.sendDataLayeronHelpDesk()\n window.open(\n 'https://api.whatsapp.com/send/?phone=6281290050800&text=Halo,%20saya%20perlu%20informasi%20mengenai%20kompas.id'\n )\n }\n\n private paymentExtensionHandler(): void {\n this.isExtensionsOpened = !this.isExtensionsOpened\n }\n\n get isDark() {\n return this.theme === 'dark'\n }\n\n get redirectToLogin() {\n return `${this.kompasLoginHost}?next=${encodeURIComponent(\n this.selfHost + window.location.pathname\n )}`\n }\n\n private async getRegisterToken(path: string, payload: any): Promise<string> {\n return fetch(`${this.kompasApigenHost}/v1/user/register/token/${path}`, {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: {\n 'content-type': 'application/json',\n },\n })\n .then(response => response.json())\n .then((data: any) => data.result.token)\n .catch(error => {\n throw error\n })\n }\n\n private async getUserToken(path: string, payload: any): Promise<string> {\n return fetch(`${this.kompasApigenHost}/v1/user/token/${path}`, {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: {\n 'content-type': 'application/json',\n },\n })\n .then(response => response.json())\n .then((data: any) => data.result.token)\n .catch(error => {\n throw error\n })\n }\n\n private async getSubscriptionToken(\n path: string,\n payload: any\n ): Promise<string> {\n return fetch(`${this.kompasAkunHost}/api/subscription/login/${path}`, {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: {\n 'content-type': 'application/json',\n },\n })\n .then(response => response.json())\n .then((data: any) => {\n this.errorFlag = 0\n return data.access_token\n })\n .catch(async error => {\n const errorCode = error.response.status\n if (errorCode === 500 && this.errorFlag < 5) {\n // eslint-disable-next-line no-plusplus\n this.errorFlag++\n setTimeout(async () => {\n await this.getSubscriptionToken(path, payload)\n }, 2000)\n } else {\n this.errorFlag = 0\n throw error\n }\n })\n }\n\n private async createSwG(payload: any, token: string) {\n await fetch(`${this.kompasApiWcmHost}/v2/membership/swg/create`, {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: {\n 'content-type': 'application/json',\n Authorization: `Bearer ${token}`,\n },\n })\n .then(response => response.json())\n .catch(error => {\n throw error\n })\n }\n\n private subscribeWithGoogleButton = (): any => {\n // @ts-ignore\n // eslint-disable-next-line no-restricted-globals\n ;(self.SWG = self.SWG || []).push((subscriptions: any) => {\n // set entitlement\n subscriptions.setOnEntitlementsResponse(() => {\n // subscriptions attach button\n subscriptions.attachButton(\n this.buttonElement,\n { theme: 'light', lang: 'en' },\n () => {\n subscriptions.showOffers({ isClosable: true })\n subscriptions.setOnLoginRequest(() => {\n window.location.href = this.redirectToLogin\n })\n subscriptions.setOnPaymentResponse(async (paymentResponse: any) => {\n const response = await paymentResponse\n const raw = JSON.parse(response.purchaseData.raw)\n const { productId, purchaseToken, packageName } = raw\n const { email } = response.userData.data\n\n const payload = {\n subscription_token: purchaseToken,\n products: productId,\n detail: 'test',\n }\n const userToken = await this.getUserToken('google', payload)\n if (userToken) {\n // login and update membership\n const accessToken = await this.getSubscriptionToken('google', {\n token: userToken,\n })\n if (accessToken) {\n const payloadSWG = {\n email,\n package_name: packageName,\n product_id: productId,\n purchase_token: purchaseToken,\n }\n await this.createSwG(payloadSWG, accessToken)\n }\n } else {\n // register and login the unknown user\n const payloadRegisterToken = {\n subscription_token: purchaseToken,\n products: productId,\n detail: 'test',\n }\n const token = await this.getRegisterToken(\n 'google',\n payloadRegisterToken\n )\n if (token) {\n const accessToken = await this.getSubscriptionToken(\n 'google',\n { token }\n )\n const payloadSWRUknown = {\n email,\n package_name: packageName,\n product_id: productId,\n purchase_token: purchaseToken,\n }\n await this.createSwG(payloadSWRUknown, accessToken)\n }\n }\n response.complete().then(() => {\n window.location.href = this.redirectToLogin\n })\n })\n }\n )\n })\n })\n }\n\n private jsonScript() {\n const jsonData = {\n '@context': 'https://schema.org',\n '@type': ['WebSite', 'WebPage'],\n isAccessibleForFree: false,\n url: this.selfHost + window.location.pathname,\n name: this.swgPublisherName,\n hasPart: {\n '@type': 'WebPageElement',\n },\n isPartOf: {\n '@type': ['CreativeWork', 'Product'],\n name: this.swgPublisherId,\n productID: this.swgProductId,\n },\n }\n const str = JSON.stringify(jsonData)\n const jsonScript = document.createElement('script')\n jsonScript.type = 'application/ld+json'\n jsonScript.text = str\n jsonScript.defer = true\n const jsonHead = document.querySelector('head')\n if (jsonHead) {\n jsonHead.appendChild(jsonScript)\n }\n }\n\n override connectedCallback() {\n // eslint-disable-next-line wc/guard-super-call\n super.connectedCallback()\n if (this.swgEnable) {\n this.jsonScript()\n const appendSWGButton = () => {\n this.buttonElement = this.shadowRoot?.getElementById(\n 'subscribe-with-google'\n ) as HTMLButtonElement\n if (this.buttonElement) {\n const head = document.querySelector('head')\n const script = document.createElement('script')\n script.src = 'https://news.google.com/swg/js/v1/swg.js'\n script.defer = true\n script.onload = this.subscribeWithGoogleButton()\n if (head) {\n head.appendChild(script)\n }\n }\n }\n\n setTimeout(appendSWGButton, 500)\n }\n }\n\n private sendDataLayer(): void {\n window.dataLayer.push({\n event: 'halamanBerlanggananClick',\n subscriptionStatus: '',\n GUID: '',\n interface: deviceType(),\n })\n }\n\n private sendDataLayeronHelpDesk(): void {\n window.dataLayer.push({\n event: 'helpOfferClick',\n userType: this.subscriptionStatus,\n GUID: this.userGuid,\n interface: deviceType(),\n })\n }\n\n private sendDataLayeronButtonBuyPackage(\n name: string,\n id: string,\n price: number,\n position: number\n ): void {\n const gtmParams: Record<string, any> = {\n event: 'subscribe_button_clicked',\n paywall_location: this.paywall_location,\n paywall_subscription_package: name,\n paywall_subscription_id: id,\n paywall_subscription_price: price,\n paywall_position: position,\n user_type: this.tracker_user_type,\n subscription_status: this.tracker_subscription_status,\n page_domain: this.tracker_page_domain || 'Kompas.id',\n metered_wall_type: this.tracker_metered_wall_type || 'HP',\n metered_wall_balance: this.tracker_metered_wall_balance,\n }\n\n if (this.type !== 'epaper') {\n gtmParams.content_title = this.tracker_content_title\n gtmParams.content_id = this.tracker_content_id\n gtmParams.content_categories = this.tracker_content_categories\n gtmParams.content_type = this.tracker_content_type\n gtmParams.page_type = this.tracker_page_type\n } else {\n gtmParams.epaper_edition = this.tracker_epaper_edition\n }\n\n window.dataLayer.push(gtmParams)\n }\n\n private sendDataLayeronPaywallBody = (): void => {\n const gtmParams: Record<string, any> = {\n event: 'paywall_viewed',\n impressions: [\n {\n paywall_location: this.paywall_location || '',\n paywall_subscription_package:\n 'Cash-B2C-Halaman Berlangganan-Reguler_Digital-KDP 12',\n paywall_subscription_id: '9802032',\n paywall_subscription_price: 360000,\n paywall_position: 1,\n user_type: this.tracker_user_type,\n subscription_status: this.tracker_subscription_status,\n page_domain: this.tracker_page_domain || 'Kompas.id',\n metered_wall_type: this.tracker_metered_wall_type || 'HP',\n metered_wall_balance: this.tracker_metered_wall_balance,\n },\n {\n paywall_location: this.paywall_location || '',\n paywall_subscription_package:\n 'Cash-B2C-Halaman Berlangganan-Reguler_Digital-KDP 1',\n paywall_subscription_id: '9802035',\n paywall_subscription_price: 50000,\n paywall_position: 2,\n user_type: this.tracker_user_type,\n subscription_status: this.tracker_subscription_status,\n page_domain: this.tracker_page_domain || 'Kompas.id',\n metered_wall_type: this.tracker_metered_wall_type || 'HP',\n metered_wall_balance: this.tracker_metered_wall_balance,\n },\n ],\n }\n\n if (this.type === 'epaper') {\n gtmParams.impressions[0].epaper_edition = this.tracker_epaper_edition\n gtmParams.impressions[1].epaper_edition = this.tracker_epaper_edition\n } else {\n gtmParams.impressions[0].page_type = this.tracker_page_type\n gtmParams.impressions[0].content_id = this.tracker_content_id\n gtmParams.impressions[0].content_title = this.tracker_content_title\n gtmParams.impressions[0].content_categories =\n this.tracker_content_categories\n gtmParams.impressions[0].content_type = this.tracker_content_type\n\n gtmParams.impressions[1].page_type = this.tracker_page_type\n gtmParams.impressions[1].content_id = this.tracker_content_id\n gtmParams.impressions[1].content_title = this.tracker_content_title\n gtmParams.impressions[1].content_categories =\n this.tracker_content_categories\n gtmParams.impressions[1].content_type = this.tracker_content_type\n }\n\n window.dataLayer.push(gtmParams)\n }\n\n private headerSection(type: 'epaper' | 'reguler') {\n return html`\n <div class=\"flex w-full items-center\">\n ${type === 'epaper'\n ? html`<button\n @click=${() => this.redirectToPrevUrl()}\n class=\"hidden lg:block w-8 h-8 text-blue-600 pl-4\"\n >\n ${unsafeSVG(getFontAwesomeIcon('fas', 'arrow-left'))}\n </button>`\n : ''}\n <h4\n class=\"text-base md:text-xl ${this.isDark &&\n 'text-white'} text-center font-bold font-serif tracking-wide md:tracking-normal w-full\"\n >\n Langganan untuk Lanjut Membaca\n </h4>\n </div>\n `\n }\n\n private descriptionSection(data: Array<string>) {\n return html`<div class=\" flex flex-col items-center\">\n <div class=\"flex flex-col space-y-2 mt-2.5 md:mt-3\">\n ${data.map(\n item =>\n html`\n <div class=\"flex items-center\">\n <div class=\"text-green-500\">\n ${unsafeSVG(getFontAwesomeIcon('fas', 'check', 12, 12))}\n </div>\n <h6\n class=\"text-xs md:text-base ${this.isDark &&\n 'text-white'} ml-0.5 md:ml-1\"\n >\n ${item}\n </h6>\n </div>\n `\n )}\n </div>\n </div>`\n }\n\n private informationPackages() {\n return html` <div class=\"mt-4 flex justify-center\">\n <button\n @click=${() => this.redirectToSubscriber()}\n class=\"text-sm md:text-base font-bold ${this.isDark\n ? 'text-blue-300'\n : 'text-blue-600'} underline\"\n >\n Lihat Paket Lainnya\n </button>\n </div>`\n }\n\n private separatorLine() {\n return html`\n <div class=\"flex flex-row w-full justify-center\">\n <div\n class=\"border-b-2 ${this.isDark\n ? 'border-dark-2'\n : 'border-blue-200'} w-1/4 my-4 flex justify-center\"\n ></div>\n <p class=\"px-4 pt-1 ${this.isDark && 'text-dark-1'}\">atau</p>\n <div\n class=\"border-b-2 ${this.isDark\n ? 'border-dark-2'\n : 'border-blue-200'} w-1/4 my-4 flex justify-center\"\n ></div>\n </div>\n `\n }\n\n private paymentDesktopSection(data: Array<PaymentImage>) {\n return html`\n <div\n class=\"hidden md:flex w-full md:max-w-sm items-center justify-center flex-wrap\"\n >\n ${data.map(\n item =>\n html`<img\n class=\"object-cover ${this.isDark ? 'h-9' : 'h-10'}\"\n src=${item.link}\n alt=\"${item.name}-logo-payment\"\n />`\n )}\n </div>\n `\n }\n\n private paymentMobileSection(data: Array<PaymentImage>) {\n return html`\n <div\n class=\"grid md:hidden items-center grid-flow-col grid-cols-auto grid-rows-1 mt-4 mx-4\"\n >\n ${data.map(\n item =>\n html`<img\n class=\"w-16\"\n src=${item.link}\n alt=\"${item.name}-logo-payment\"\n />`\n )}\n <button\n @click=${() => this.paymentExtensionHandler()}\n class=\"text-xs md:text-sm ${this.isDark\n ? 'text-blue-300'\n : 'text-blue-600'} font-bold\"\n >\n +9 lainnya\n </button>\n </div>\n `\n }\n\n private paymentMobileExtension(data: Array<PaymentImage>) {\n return html`\n <div\n class=\"w-full ${this.isDark\n ? '-bottom-6'\n : 'bottom-0'} max-w-xs mb-1 ml-8 md:hidden absolute px-4\"\n >\n <div\n class=\"w-full ${this.isDark\n ? 'bg-dark-6 border-dark-6'\n : 'bg-white border-white'} rounded p-3 max-w-xs\"\n >\n <svg\n class=\"right-0 ${this.isDark\n ? 'text-dark-6 border-dark-6'\n : 'text-white border-white '} h-4 mr-10 -mt-7 z-0 transform rotate-180 absolute\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 255 255\"\n >\n <polygon class=\"fill-current\" points=\"0,0 127.5,127.5 255,0\" />\n </svg>\n <div\n class=\"grid place-items-center items-center grid-flow-row grid-cols-5 grid-rows-2 gap-y-4\"\n >\n ${data.map(\n item =>\n html`<img\n class=\"object-cover\"\n src=${item.link}\n alt=\"${item.name}-logo-payment\"\n />`\n )}\n </div>\n </div>\n </div>\n `\n }\n\n private primaryPackages(product: Product) {\n return html`\n <div\n class=\"flex flex-wrap justify-between items-center ${this.isDark\n ? 'bg-grey-600'\n : 'bg-white'} rounded md:mx-0 w-full max-w-xs md:max-w-sm md:w-3/5 mt-2.5 md:mt-4 border border-yellow-400 relative\"\n >\n <div class=\"flex flex-col py-3 px-4\">\n <div class=\"flex flex-none items-center\">\n <h5 class=\"text-base md:text-lg font-bold text-orange-400\">\n ${this.getRupiahFormat(product.price)}\n </h5>\n <h6\n class=\"text-xs md:text-base ${this.isDark &&\n 'text-white'} font-bold pl-1\"\n >\n / ${product.periode}\n </h6>\n </div>\n <div class=\"flex items-center\">\n <p class=\"text-xs ${this.isDark && 'text-white'}\">\n hanya <span class=\"text-orange-400\">Rp 30.000</span> / bulan\n </p>\n </div>\n </div>\n <button\n class=\"h-auto ${this.isDark\n ? 'bg-green-300 border border-green-400'\n : 'bg-green-500'} rounded mr-4\"\n @click=${() =>\n this.redirectToCheckout(\n product.url,\n 'Cash-B2C-Halaman Berlangganan-Reguler_Digital-KDP 12',\n '9802032',\n 360000,\n 1\n )}\n >\n <h6\n class=\"text-xs md:text-base ${this.isDark\n ? 'text-black'\n : 'text-white'} font-bold py-2 px-4\"\n >\n Langganan\n </h6>\n </button>\n <div class=\"absolute -top-2 left-4\">\n <div class=\"rounded bg-yellow-300 px-2 py-0.5 text-xs\">\n <b>Harga Terbaik</b>\n </div>\n </div>\n </div>\n `\n }\n\n private secondaryPackages(product: Product) {\n return html`\n <div\n class=\"flex flex-wrap justify-between ${this.isDark\n ? 'bg-grey-600'\n : 'bg-white'} py-3 px-4 rounded md:mx-0 w-full max-w-xs md:max-w-sm md:w-3/5 mt-3 md:mt-4\"\n >\n <div class=\"flex items-center\">\n <h5 class=\"text-base md:text-lg font-bold text-orange-400\">\n ${this.getRupiahFormat(product.price)}\n </h5>\n <h6\n class=\"text-xs md:text-base ${this.isDark &&\n 'text-white'} font-bold pl-1\"\n >\n / ${product.periode}\n </h6>\n </div>\n <button\n @click=${() =>\n this.redirectToCheckout(\n product.url,\n 'Cash-B2C-Halaman Berlangganan-Reguler_Digital-KDP 1',\n '9802035',\n 50000,\n 2\n )}\n class=\"h-auto ${!this.isDark &&\n 'bg-white'} border border-green-500 rounded\"\n >\n <h6\n class=\"text-xs md:text-base ${this.isDark\n ? 'text-green-300'\n : 'text-green-500'} font-bold py-2 px-4\"\n >\n Langganan\n </h6>\n </button>\n </div>\n `\n }\n\n private packagesSection(data: Packages) {\n return html`\n <div class=\"flex flex-col w-full items-center mt-8 lg:mt-2 px-2 \">\n <h6\n class=\"text-sm md:text-base ${this.isDark && 'text-white'} font-bold\"\n >\n ${data.title}\n </h6>\n ${data.memberships.map(item =>\n item.isHighlight\n ? this.primaryPackages(item)\n : this.secondaryPackages(item)\n )}\n </div>\n `\n }\n\n private topNavigator() {\n return html`\n <div class=\"flex lg:hidden items-center w-full pb-4 \">\n <button\n @click=${() => this.redirectToPrevUrl()}\n class=\"text-xs md:text-lg text-white flex flex-row\"\n >\n <div class=\"icon-lg icon-white w-4 h-4 mr-3.5 md:mr-5 pt-0.5\">\n ${unsafeSVG(getFontAwesomeIcon('fas', 'arrow-left'))}\n </div>\n Kembali\n </button>\n </div>\n `\n }\n\n private helpDesk() {\n return html`\n <div class=\"py-2.5 text-white self-center text-xs md:text-sm\">\n Mengalami masalah? Hubungi\n <button\n @click=${() => this.redirectToHelpdesk()}\n class=\"font-bold ${this.isDark && 'text-blue-300'} underline\"\n >\n Layanan Pelanggan.\n </button>\n </div>\n `\n }\n\n private authRegister() {\n return html`\n <div\n class=\"flex flex-row text-white px-2 py-2.5 space-x-4 md:space-x-8 self-center\"\n >\n <div class=\"flex flex-col text-left text-xs md:text-sm text-white\">\n <b>Sudah berlangganan Kompas.id?</b>\n <p>Masuk untuk lanjut membaca.</p>\n </div>\n <button\n @click=${() => this.redirectToRegister()}\n class=\"h-auto ${this.isDark\n ? 'bg-blue-300'\n : 'bg-grey-100'} rounded mr-3\"\n >\n <p\n class=\"text-xs md:text-sm ${this.isDark\n ? 'text-black'\n : 'text-blue-600'} font-bold py-2 px-4\"\n >\n Masuk / Daftar\n </p>\n </button>\n </div>\n `\n }\n\n private userAction(isLogin: boolean, type: 'epaper' | 'reguler') {\n return html`\n <div\n class=\"flex h-20 ${this.isDark\n ? 'bg-dark-4'\n : 'bg-blue-600'} w-full justify-evenly rounded-b mt-6 md:mt-8 relative\"\n >\n ${isLogin || type !== 'epaper' ? this.helpDesk() : this.authRegister()}\n </div>\n `\n }\n\n render() {\n return html`\n <div\n class=\"${this.type === 'epaper'\n ? 'bg-transparent wrapper-body'\n : 'wrapper-body'}\"\n >\n <div\n class=\"flex flex-col justify-center items-center w-full max-w-screen-sm px-4 md:px-0 my-5 relative\"\n >\n ${this.type === 'epaper' ? this.topNavigator() : ''}\n <div\n class=\"flex w-full flex-col items-center justify-center ${this\n .isDark\n ? 'bg-dark-3'\n : 'bg-blue-100'} rounded pt-6 md:pt-8 relative\"\n >\n ${this.headerSection(this.type)}\n ${this.descriptionSection(\n this.paywallData?.informations?.description ?? []\n )}\n ${this.packagesSection(\n this.paywallData?.packages ?? ({} as Packages)\n )}\n ${this.informationPackages()}\n ${this.swgEnable ? this.separatorLine() : null}\n ${this.swgEnable\n ? html`<button\n class=\"border-2 bg-grey-100 border-grey-100 rounded-lg px-6 shadow-sm flex flex-row py-2 mt-1 mb-4\"\n id=\"subscribe-with-google\"\n >\n <p>Subscribe with</p>\n <img class=\"pl-2 object-scale-down w-20 pt-0.5\" src=\"https://kompasid-production-www.s3.ap-southeast-1.amazonaws.com/paywall-asset/google.png\" alt=\"subscribe with google\"></img>\n </button>`\n : null}\n ${this.paymentDesktopSection(\n this.paywallData?.payment?.desktop ?? []\n )}\n ${this.paymentMobileSection(\n this.paywallData?.payment?.mobile ?? []\n )}\n ${this.userAction(this.isLogin, this.type)}\n ${this.sendDataLayeronPaywallBody()}\n </div>\n ${this.isExtensionsOpened\n ? this.paymentMobileExtension(\n this.paywallData?.payment?.ekstension ?? []\n )\n : ''}\n </div>\n </div>\n `\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"KompasPaywallInformationHeader.js","sourceRoot":"","sources":["../../../../src/components/kompas-paywall-information-header/KompasPaywallInformationHeader.ts"],"names":[],"mappings":";AAAA,2CAA2C;AAC3C,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAA;AAGjD,IAAM,8BAA8B,GAApC,MAAM,8BAA+B,SAAQ,UAAU;IAAvD;;QAGuB,SAAI,GAAG,EAAE,CAAA;QACT,UAAK,GAAG,EAAE,CAAA;IAkBxC,CAAC;IAhBC,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,KAAK,MAAM,CAAA;IAC9B,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAA;;;oDAGqC,IAAI,CAAC,KAAK,KAAK,MAAM;YAC/D,YAAY;;YAEV,IAAI,CAAC,IAAI;;;KAGhB,CAAA;IACH,CAAC;;AApBM,qCAAM,GAAG,CAAC,GAAG,CAAA,EAAE,EAAE,QAAQ,CAAC,CAAA;AAEL;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;4DAAU;AACT;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6DAAW;AAJ3B,8BAA8B;IAD1C,aAAa,CAAC,mCAAmC,CAAC;GACtC,8BAA8B,CAsB1C;SAtBY,8BAA8B","sourcesContent":["/* eslint-disable class-methods-use-this */\nimport { html, css, LitElement } from 'lit'\nimport { property, customElement } from 'lit/decorators.js'\nimport { TWStyles } from '../../../tailwind/tailwind.js'\n\n@customElement('kompas-paywall-information-header')\nexport class KompasPaywallInformationHeader extends LitElement {\n static styles = [css``, TWStyles]\n\n @property({ type: String }) text = ''\n @property({ type: String }) theme = ''\n\n get isDark() {\n return this.theme === 'dark'\n }\n\n render() {\n return html`\n <div class=\"my-4 md:my-8\">\n <h5\n class=\"text-base text-center md:text-xl ${this.theme === 'dark' &&\n 'text-white'} font-bold font-serif\"\n >\n ${this.text}\n </h5>\n </div>\n `\n }\n}\n"]}
@@ -1,240 +0,0 @@
1
- import { __decorate } from "tslib";
2
- /* eslint-disable class-methods-use-this */
3
- import { html, css, LitElement } from 'lit';
4
- import { property, customElement, state } from 'lit/decorators.js';
5
- import { TWStyles } from '../../../tailwind/tailwind.js';
6
- import { deviceType } from '../../utils/deviceType.js';
7
- let KompasPaywallVideo = class KompasPaywallVideo extends LitElement {
8
- constructor() {
9
- super(...arguments);
10
- /**
11
- * Props
12
- */
13
- /**
14
- * prop isLogin untuk menghandle apakah user sudah login atau belum
15
- * prop paywall_location = The location where user encounter the paywall
16
- * prop paywall_subscription_package = The name of the subscription package viewed by user
17
- * prop paywall_subscription_id = The ID of the subscription package viewed by user
18
- * prop paywall_subscription_price = The price of the subscriprtion package viewed by user
19
- * prop paywall_position = The position of the subscription package viewed by user
20
- * prop page_type = Type of the page
21
- * prop content_id = ID of article (slug)
22
- * prop content_type = Whether it's free article or paid article
23
- * prop content_title = The title of article
24
- * prop tracker_content_categories = The category of the content
25
- * prop user_type = Type of user based on their subscription
26
- * prop subscription_status = Status of their subscription
27
- * prop page_domain = Page Domain
28
- * prop metered_wall_type = The type of Metered Wall
29
- * prop metered_wall_balance = The balance of their metered wall
30
- */
31
- this.subscriptionUrl = 'https://www.kompas.id/berlangganan';
32
- this.isLogin = false;
33
- this.paywall_location = '';
34
- this.paywall_subscription_package = '';
35
- this.paywall_subscription_id = '';
36
- this.paywall_subscription_price = 0;
37
- this.paywall_position = 0;
38
- this.tracker_page_type = '';
39
- this.tracker_content_id = '';
40
- this.tracker_content_title = '';
41
- this.tracker_content_categories = '';
42
- this.tracker_content_type = '';
43
- this.tracker_user_type = '';
44
- this.tracker_subscription_status = '';
45
- this.tracker_page_domain = '';
46
- this.tracker_metered_wall_type = '';
47
- this.tracker_metered_wall_balance = 0;
48
- this.sendDataLayeronNonLogin = () => {
49
- window.dataLayer.push({
50
- event: 'registrationOfferimppression',
51
- interface: deviceType(),
52
- });
53
- };
54
- this.sendDataLayeronBerlangganan = () => {
55
- window.dataLayer.push({
56
- event: 'paywall_viewed',
57
- paywall_location: this.paywall_location,
58
- paywall_subscription_package: this.paywall_subscription_package,
59
- paywall_subscription_id: this.paywall_subscription_id,
60
- paywall_subscription_price: this.paywall_subscription_price,
61
- paywall_position: this.paywall_position,
62
- page_type: this.tracker_page_type,
63
- content_id: this.tracker_content_id,
64
- content_title: this.tracker_content_title,
65
- content_categories: this.tracker_content_categories,
66
- content_type: this.tracker_content_type,
67
- user_type: this.tracker_user_type,
68
- subscription_status: this.tracker_subscription_status,
69
- page_domain: this.tracker_page_domain || 'Kompas.id',
70
- metered_wall_type: this.tracker_metered_wall_type || 'HP',
71
- metered_wall_balance: this.tracker_metered_wall_balance,
72
- });
73
- };
74
- this.sendDataLayeronButtonLogin = (triggerClick) => {
75
- window.dataLayer.push({
76
- event: 'registrationOfferClick',
77
- interface: deviceType(),
78
- buttonClicked: triggerClick,
79
- });
80
- };
81
- this.sendDataLayeronButtonBerlangganan = () => {
82
- window.dataLayer.push({
83
- event: 'subscribe_button_clicked',
84
- paywall_location: this.paywall_location,
85
- paywall_subscription_package: this.paywall_subscription_package,
86
- paywall_subscription_id: this.paywall_subscription_id,
87
- paywall_subscription_price: this.paywall_subscription_price,
88
- paywall_position: this.paywall_position,
89
- page_type: this.tracker_page_type,
90
- content_id: this.tracker_content_id,
91
- content_title: this.tracker_content_title,
92
- content_categories: this.tracker_content_categories,
93
- content_type: this.tracker_content_type,
94
- user_type: this.tracker_user_type,
95
- subscription_status: this.tracker_subscription_status,
96
- page_domain: this.tracker_page_domain || 'Kompas.id',
97
- metered_wall_type: this.tracker_metered_wall_type || 'HP',
98
- metered_wall_balance: this.tracker_metered_wall_balance,
99
- });
100
- };
101
- }
102
- isLoginComponent() {
103
- return html `
104
- <div>
105
- ${this.sendDataLayeronBerlangganan()}
106
- <h5
107
- class="leading-6 text-white text-center text-base md:text-xl max-w-2xl"
108
- >
109
- Akses konten premium Anda bulan ini sudah habis. Aktifkan langganan
110
- untuk akses tanpa batas, mulai dari
111
- <span class="font-bold">Rp50.000/bulan.</span>
112
- </h5>
113
- <div class="flex justify-between mt-4">
114
- <button
115
- @click=${() => this.redirectToBerlangganan()}
116
- class="bg-green-500 rounded px-4 py-1.5 text-sm text-white font-bold"
117
- >
118
- Berlangganan
119
- </button>
120
- </div>
121
- </div>
122
- `;
123
- }
124
- defaultComponent() {
125
- return html `
126
- <div>
127
- ${this.sendDataLayeronNonLogin()} ${this.sendDataLayeronBerlangganan()}
128
- <h5
129
- class="leading-6 text-white text-center text-base md:text-xl max-w-xl"
130
- >
131
- Langganan untuk akses ke seluruh konten premium, mulai dari
132
- <span class="font-bold">Rp50.000/bulan.</span>
133
- </h5>
134
- <div class="flex justify-center mt-4 space-x-3">
135
- <button
136
- @click=${() => this.redirectToRegister('Masuk')}
137
- class="rounded text-sm text-white px-4 py-1.5 ring-1 ring-grey-100"
138
- >
139
- Masuk
140
- </button>
141
- <button
142
- @click=${() => this.redirectToBerlangganan()}
143
- class="bg-green-500 rounded px-4 py-1.5 text-sm text-white font-bold"
144
- >
145
- Berlangganan
146
- </button>
147
- </div>
148
- <p
149
- class="text-center text-sm leading-4 text-white mt-6 max-w-xs md:max-w-none"
150
- >
151
- Dapatkan 5 konten premium gratis tiap bulan!
152
- <button
153
- @click=${() => this.redirectToRegister('Coba Sekarang')}
154
- target="_blank"
155
- class="text-blue-300 font-bold cursor-pointer"
156
- >
157
- Coba Sekarang
158
- </button>
159
- </p>
160
- </div>
161
- `;
162
- }
163
- redirectToRegister(triggerClick) {
164
- this.sendDataLayeronButtonLogin(triggerClick);
165
- const registerHost = 'https://account.kompas.id/register';
166
- const nextParams = encodeURIComponent(window.location.href);
167
- const directUrlRegister = `${registerHost}?next=${nextParams}?status=sukses_login&status_login=login`;
168
- window.open(directUrlRegister, '_blank');
169
- }
170
- redirectToBerlangganan() {
171
- this.sendDataLayeronButtonBerlangganan();
172
- window.open(this.subscriptionUrl, '_blank');
173
- }
174
- render() {
175
- return html `
176
- <div
177
- class="radius absolute z-20 bg-black bg-opacity-50 p-4 top-0 bottom-0 left-0 flex flex-col w-full h-full justify-center items-center"
178
- >
179
- ${this.isLogin ? this.isLoginComponent() : this.defaultComponent()}
180
- </div>
181
- `;
182
- }
183
- };
184
- KompasPaywallVideo.styles = [css ``, TWStyles];
185
- __decorate([
186
- state()
187
- ], KompasPaywallVideo.prototype, "subscriptionUrl", void 0);
188
- __decorate([
189
- property({ type: Boolean })
190
- ], KompasPaywallVideo.prototype, "isLogin", void 0);
191
- __decorate([
192
- property({ type: String })
193
- ], KompasPaywallVideo.prototype, "paywall_location", void 0);
194
- __decorate([
195
- property({ type: String })
196
- ], KompasPaywallVideo.prototype, "paywall_subscription_package", void 0);
197
- __decorate([
198
- property({ type: String })
199
- ], KompasPaywallVideo.prototype, "paywall_subscription_id", void 0);
200
- __decorate([
201
- property({ type: Number })
202
- ], KompasPaywallVideo.prototype, "paywall_subscription_price", void 0);
203
- __decorate([
204
- property({ type: Number })
205
- ], KompasPaywallVideo.prototype, "paywall_position", void 0);
206
- __decorate([
207
- property({ type: String })
208
- ], KompasPaywallVideo.prototype, "tracker_page_type", void 0);
209
- __decorate([
210
- property({ type: String })
211
- ], KompasPaywallVideo.prototype, "tracker_content_id", void 0);
212
- __decorate([
213
- property({ type: String })
214
- ], KompasPaywallVideo.prototype, "tracker_content_title", void 0);
215
- __decorate([
216
- property({ type: String })
217
- ], KompasPaywallVideo.prototype, "tracker_content_categories", void 0);
218
- __decorate([
219
- property({ type: String })
220
- ], KompasPaywallVideo.prototype, "tracker_content_type", void 0);
221
- __decorate([
222
- property({ type: String })
223
- ], KompasPaywallVideo.prototype, "tracker_user_type", void 0);
224
- __decorate([
225
- property({ type: String })
226
- ], KompasPaywallVideo.prototype, "tracker_subscription_status", void 0);
227
- __decorate([
228
- property({ type: String })
229
- ], KompasPaywallVideo.prototype, "tracker_page_domain", void 0);
230
- __decorate([
231
- property({ type: String })
232
- ], KompasPaywallVideo.prototype, "tracker_metered_wall_type", void 0);
233
- __decorate([
234
- property({ type: Number })
235
- ], KompasPaywallVideo.prototype, "tracker_metered_wall_balance", void 0);
236
- KompasPaywallVideo = __decorate([
237
- customElement('kompas-paywall-video')
238
- ], KompasPaywallVideo);
239
- export { KompasPaywallVideo };
240
- //# sourceMappingURL=KompasPaywallVideo.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KompasPaywallVideo.js","sourceRoot":"","sources":["../../../../src/components/kompas-paywall-video/KompasPaywallVideo.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this */\nimport { html, css, LitElement } from 'lit'\nimport { property, customElement, state } from 'lit/decorators.js'\nimport { TWStyles } from '../../../tailwind/tailwind.js'\nimport { deviceType } from '../../utils/deviceType.js'\n\n@customElement('kompas-paywall-video')\nexport class KompasPaywallVideo extends LitElement {\n static styles = [css``, TWStyles]\n\n /**\n * Props\n */\n /**\n * prop isLogin untuk menghandle apakah user sudah login atau belum\n * prop paywall_location = The location where user encounter the paywall\n * prop paywall_subscription_package = The name of the subscription package viewed by user\n * prop paywall_subscription_id = The ID of the subscription package viewed by user\n * prop paywall_subscription_price = The price of the subscriprtion package viewed by user\n * prop paywall_position = The position of the subscription package viewed by user\n * prop page_type = Type of the page\n * prop content_id = ID of article (slug)\n * prop content_type = Whether it's free article or paid article\n * prop content_title = The title of article\n * prop tracker_content_categories = The category of the content\n * prop user_type = Type of user based on their subscription\n * prop subscription_status = Status of their subscription\n * prop page_domain = Page Domain\n * prop metered_wall_type = The type of Metered Wall\n * prop metered_wall_balance = The balance of their metered wall\n */\n\n @state() private subscriptionUrl: string =\n 'https://www.kompas.id/berlangganan'\n\n @property({ type: Boolean }) isLogin = false\n @property({ type: String }) paywall_location = ''\n @property({ type: String }) paywall_subscription_package = ''\n @property({ type: String }) paywall_subscription_id = ''\n @property({ type: Number }) paywall_subscription_price = 0\n @property({ type: Number }) paywall_position = 0\n @property({ type: String }) tracker_page_type = ''\n @property({ type: String }) tracker_content_id = ''\n @property({ type: String }) tracker_content_title = ''\n @property({ type: String }) tracker_content_categories = ''\n @property({ type: String }) tracker_content_type = ''\n @property({ type: String }) tracker_user_type = ''\n @property({ type: String }) tracker_subscription_status = ''\n @property({ type: String }) tracker_page_domain = ''\n @property({ type: String }) tracker_metered_wall_type = ''\n @property({ type: Number }) tracker_metered_wall_balance = 0\n\n private isLoginComponent() {\n return html`\n <div>\n ${this.sendDataLayeronBerlangganan()}\n <h5\n class=\"leading-6 text-white text-center text-base md:text-xl max-w-2xl\"\n >\n Akses konten premium Anda bulan ini sudah habis. Aktifkan langganan\n untuk akses tanpa batas, mulai dari\n <span class=\"font-bold\">Rp50.000/bulan.</span>\n </h5>\n <div class=\"flex justify-between mt-4\">\n <button\n @click=${() => this.redirectToBerlangganan()}\n class=\"bg-green-500 rounded px-4 py-1.5 text-sm text-white font-bold\"\n >\n Berlangganan\n </button>\n </div>\n </div>\n `\n }\n\n private defaultComponent() {\n return html`\n <div>\n ${this.sendDataLayeronNonLogin()} ${this.sendDataLayeronBerlangganan()}\n <h5\n class=\"leading-6 text-white text-center text-base md:text-xl max-w-xl\"\n >\n Langganan untuk akses ke seluruh konten premium, mulai dari\n <span class=\"font-bold\">Rp50.000/bulan.</span>\n </h5>\n <div class=\"flex justify-center mt-4 space-x-3\">\n <button\n @click=${() => this.redirectToRegister('Masuk')}\n class=\"rounded text-sm text-white px-4 py-1.5 ring-1 ring-grey-100\"\n >\n Masuk\n </button>\n <button\n @click=${() => this.redirectToBerlangganan()}\n class=\"bg-green-500 rounded px-4 py-1.5 text-sm text-white font-bold\"\n >\n Berlangganan\n </button>\n </div>\n <p\n class=\"text-center text-sm leading-4 text-white mt-6 max-w-xs md:max-w-none\"\n >\n Dapatkan 5 konten premium gratis tiap bulan!\n <button\n @click=${() => this.redirectToRegister('Coba Sekarang')}\n target=\"_blank\"\n class=\"text-blue-300 font-bold cursor-pointer\"\n >\n Coba Sekarang\n </button>\n </p>\n </div>\n `\n }\n\n private sendDataLayeronNonLogin = (): void => {\n window.dataLayer.push({\n event: 'registrationOfferimppression',\n interface: deviceType(),\n })\n }\n\n private sendDataLayeronBerlangganan = (): void => {\n window.dataLayer.push({\n event: 'paywall_viewed',\n paywall_location: this.paywall_location,\n paywall_subscription_package: this.paywall_subscription_package,\n paywall_subscription_id: this.paywall_subscription_id,\n paywall_subscription_price: this.paywall_subscription_price,\n paywall_position: this.paywall_position,\n page_type: this.tracker_page_type,\n content_id: this.tracker_content_id,\n content_title: this.tracker_content_title,\n content_categories: this.tracker_content_categories,\n content_type: this.tracker_content_type,\n user_type: this.tracker_user_type,\n subscription_status: this.tracker_subscription_status,\n page_domain: this.tracker_page_domain || 'Kompas.id',\n metered_wall_type: this.tracker_metered_wall_type || 'HP',\n metered_wall_balance: this.tracker_metered_wall_balance,\n })\n }\n\n private sendDataLayeronButtonLogin = (triggerClick: string): void => {\n window.dataLayer.push({\n event: 'registrationOfferClick',\n interface: deviceType(),\n buttonClicked: triggerClick,\n })\n }\n\n private sendDataLayeronButtonBerlangganan = (): void => {\n window.dataLayer.push({\n event: 'subscribe_button_clicked',\n paywall_location: this.paywall_location,\n paywall_subscription_package: this.paywall_subscription_package,\n paywall_subscription_id: this.paywall_subscription_id,\n paywall_subscription_price: this.paywall_subscription_price,\n paywall_position: this.paywall_position,\n page_type: this.tracker_page_type,\n content_id: this.tracker_content_id,\n content_title: this.tracker_content_title,\n content_categories: this.tracker_content_categories,\n content_type: this.tracker_content_type,\n user_type: this.tracker_user_type,\n subscription_status: this.tracker_subscription_status,\n page_domain: this.tracker_page_domain || 'Kompas.id',\n metered_wall_type: this.tracker_metered_wall_type || 'HP',\n metered_wall_balance: this.tracker_metered_wall_balance,\n })\n }\n\n private redirectToRegister(triggerClick: string): void {\n this.sendDataLayeronButtonLogin(triggerClick)\n const registerHost: string = 'https://account.kompas.id/register'\n const nextParams: string = encodeURIComponent(window.location.href)\n const directUrlRegister: string = `${registerHost}?next=${nextParams}?status=sukses_login&status_login=login`\n window.open(directUrlRegister, '_blank')\n }\n\n private redirectToBerlangganan(): void {\n this.sendDataLayeronButtonBerlangganan()\n window.open(this.subscriptionUrl, '_blank')\n }\n\n render() {\n return html`\n <div\n class=\"radius absolute z-20 bg-black bg-opacity-50 p-4 top-0 bottom-0 left-0 flex flex-col w-full h-full justify-center items-center\"\n >\n ${this.isLogin ? this.isLoginComponent() : this.defaultComponent()}\n </div>\n `\n }\n}\n"]}
@@ -1,195 +0,0 @@
1
- /* eslint-disable class-methods-use-this */
2
- import { html, css, LitElement } from 'lit'
3
- import { property, customElement, state } from 'lit/decorators.js'
4
- import { TWStyles } from '../../../tailwind/tailwind.js'
5
- import { deviceType } from '../../utils/deviceType.js'
6
-
7
- @customElement('kompas-paywall-video')
8
- export class KompasPaywallVideo extends LitElement {
9
- static styles = [css``, TWStyles]
10
-
11
- /**
12
- * Props
13
- */
14
- /**
15
- * prop isLogin untuk menghandle apakah user sudah login atau belum
16
- * prop paywall_location = The location where user encounter the paywall
17
- * prop paywall_subscription_package = The name of the subscription package viewed by user
18
- * prop paywall_subscription_id = The ID of the subscription package viewed by user
19
- * prop paywall_subscription_price = The price of the subscriprtion package viewed by user
20
- * prop paywall_position = The position of the subscription package viewed by user
21
- * prop page_type = Type of the page
22
- * prop content_id = ID of article (slug)
23
- * prop content_type = Whether it's free article or paid article
24
- * prop content_title = The title of article
25
- * prop tracker_content_categories = The category of the content
26
- * prop user_type = Type of user based on their subscription
27
- * prop subscription_status = Status of their subscription
28
- * prop page_domain = Page Domain
29
- * prop metered_wall_type = The type of Metered Wall
30
- * prop metered_wall_balance = The balance of their metered wall
31
- */
32
-
33
- @state() private subscriptionUrl: string =
34
- 'https://www.kompas.id/berlangganan'
35
-
36
- @property({ type: Boolean }) isLogin = false
37
- @property({ type: String }) paywall_location = ''
38
- @property({ type: String }) paywall_subscription_package = ''
39
- @property({ type: String }) paywall_subscription_id = ''
40
- @property({ type: Number }) paywall_subscription_price = 0
41
- @property({ type: Number }) paywall_position = 0
42
- @property({ type: String }) tracker_page_type = ''
43
- @property({ type: String }) tracker_content_id = ''
44
- @property({ type: String }) tracker_content_title = ''
45
- @property({ type: String }) tracker_content_categories = ''
46
- @property({ type: String }) tracker_content_type = ''
47
- @property({ type: String }) tracker_user_type = ''
48
- @property({ type: String }) tracker_subscription_status = ''
49
- @property({ type: String }) tracker_page_domain = ''
50
- @property({ type: String }) tracker_metered_wall_type = ''
51
- @property({ type: Number }) tracker_metered_wall_balance = 0
52
-
53
- private isLoginComponent() {
54
- return html`
55
- <div>
56
- ${this.sendDataLayeronBerlangganan()}
57
- <h5
58
- class="leading-6 text-white text-center text-base md:text-xl max-w-2xl"
59
- >
60
- Akses konten premium Anda bulan ini sudah habis. Aktifkan langganan
61
- untuk akses tanpa batas, mulai dari
62
- <span class="font-bold">Rp50.000/bulan.</span>
63
- </h5>
64
- <div class="flex justify-between mt-4">
65
- <button
66
- @click=${() => this.redirectToBerlangganan()}
67
- class="bg-green-500 rounded px-4 py-1.5 text-sm text-white font-bold"
68
- >
69
- Berlangganan
70
- </button>
71
- </div>
72
- </div>
73
- `
74
- }
75
-
76
- private defaultComponent() {
77
- return html`
78
- <div>
79
- ${this.sendDataLayeronNonLogin()} ${this.sendDataLayeronBerlangganan()}
80
- <h5
81
- class="leading-6 text-white text-center text-base md:text-xl max-w-xl"
82
- >
83
- Langganan untuk akses ke seluruh konten premium, mulai dari
84
- <span class="font-bold">Rp50.000/bulan.</span>
85
- </h5>
86
- <div class="flex justify-center mt-4 space-x-3">
87
- <button
88
- @click=${() => this.redirectToRegister('Masuk')}
89
- class="rounded text-sm text-white px-4 py-1.5 ring-1 ring-grey-100"
90
- >
91
- Masuk
92
- </button>
93
- <button
94
- @click=${() => this.redirectToBerlangganan()}
95
- class="bg-green-500 rounded px-4 py-1.5 text-sm text-white font-bold"
96
- >
97
- Berlangganan
98
- </button>
99
- </div>
100
- <p
101
- class="text-center text-sm leading-4 text-white mt-6 max-w-xs md:max-w-none"
102
- >
103
- Dapatkan 5 konten premium gratis tiap bulan!
104
- <button
105
- @click=${() => this.redirectToRegister('Coba Sekarang')}
106
- target="_blank"
107
- class="text-blue-300 font-bold cursor-pointer"
108
- >
109
- Coba Sekarang
110
- </button>
111
- </p>
112
- </div>
113
- `
114
- }
115
-
116
- private sendDataLayeronNonLogin = (): void => {
117
- window.dataLayer.push({
118
- event: 'registrationOfferimppression',
119
- interface: deviceType(),
120
- })
121
- }
122
-
123
- private sendDataLayeronBerlangganan = (): void => {
124
- window.dataLayer.push({
125
- event: 'paywall_viewed',
126
- paywall_location: this.paywall_location,
127
- paywall_subscription_package: this.paywall_subscription_package,
128
- paywall_subscription_id: this.paywall_subscription_id,
129
- paywall_subscription_price: this.paywall_subscription_price,
130
- paywall_position: this.paywall_position,
131
- page_type: this.tracker_page_type,
132
- content_id: this.tracker_content_id,
133
- content_title: this.tracker_content_title,
134
- content_categories: this.tracker_content_categories,
135
- content_type: this.tracker_content_type,
136
- user_type: this.tracker_user_type,
137
- subscription_status: this.tracker_subscription_status,
138
- page_domain: this.tracker_page_domain || 'Kompas.id',
139
- metered_wall_type: this.tracker_metered_wall_type || 'HP',
140
- metered_wall_balance: this.tracker_metered_wall_balance,
141
- })
142
- }
143
-
144
- private sendDataLayeronButtonLogin = (triggerClick: string): void => {
145
- window.dataLayer.push({
146
- event: 'registrationOfferClick',
147
- interface: deviceType(),
148
- buttonClicked: triggerClick,
149
- })
150
- }
151
-
152
- private sendDataLayeronButtonBerlangganan = (): void => {
153
- window.dataLayer.push({
154
- event: 'subscribe_button_clicked',
155
- paywall_location: this.paywall_location,
156
- paywall_subscription_package: this.paywall_subscription_package,
157
- paywall_subscription_id: this.paywall_subscription_id,
158
- paywall_subscription_price: this.paywall_subscription_price,
159
- paywall_position: this.paywall_position,
160
- page_type: this.tracker_page_type,
161
- content_id: this.tracker_content_id,
162
- content_title: this.tracker_content_title,
163
- content_categories: this.tracker_content_categories,
164
- content_type: this.tracker_content_type,
165
- user_type: this.tracker_user_type,
166
- subscription_status: this.tracker_subscription_status,
167
- page_domain: this.tracker_page_domain || 'Kompas.id',
168
- metered_wall_type: this.tracker_metered_wall_type || 'HP',
169
- metered_wall_balance: this.tracker_metered_wall_balance,
170
- })
171
- }
172
-
173
- private redirectToRegister(triggerClick: string): void {
174
- this.sendDataLayeronButtonLogin(triggerClick)
175
- const registerHost: string = 'https://account.kompas.id/register'
176
- const nextParams: string = encodeURIComponent(window.location.href)
177
- const directUrlRegister: string = `${registerHost}?next=${nextParams}?status=sukses_login&status_login=login`
178
- window.open(directUrlRegister, '_blank')
179
- }
180
-
181
- private redirectToBerlangganan(): void {
182
- this.sendDataLayeronButtonBerlangganan()
183
- window.open(this.subscriptionUrl, '_blank')
184
- }
185
-
186
- render() {
187
- return html`
188
- <div
189
- class="radius absolute z-20 bg-black bg-opacity-50 p-4 top-0 bottom-0 left-0 flex flex-col w-full h-full justify-center items-center"
190
- >
191
- ${this.isLogin ? this.isLoginComponent() : this.defaultComponent()}
192
- </div>
193
- `
194
- }
195
- }