// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import '../strings.m.js';
import './catalog_attributes_row.js';
import './history_graph.js';
import './insights_comment_row.js';
import './price_tracking_section.js';
import '//resources/cr_elements/cr_hidden_style.css.js';
import '//resources/cr_elements/cr_icons.css.js';
import '//resources/cr_elements/cr_shared_vars.css.js';
import '//resources/cr_elements/mwb_element_shared_style.css.js';
import '//shopping-insights-side-panel.top-chrome/shared/sp_shared_style.css.js';
import {ColorChangeUpdater} from '//resources/cr_components/color_change_listener/colors_css_updater.js';
import type {BrowserProxy} from '//resources/cr_components/commerce/browser_proxy.js';
import {BrowserProxyImpl} from '//resources/cr_components/commerce/browser_proxy.js';
import type {PriceInsightsInfo, ProductInfo} from '//resources/cr_components/commerce/shopping_service.mojom-webui.js';
import {loadTimeData} from '//resources/js/load_time_data.js';
import {listenOnce} from '//resources/js/util.js';
import {PolymerElement} from '//resources/polymer/v3_0/polymer/polymer_bundled.min.js';
import {getTemplate} from './app.html.js';
export interface ShoppingInsightsAppElement {
$: {
insightsContainer: HTMLElement,
};
}
export class ShoppingInsightsAppElement extends PolymerElement {
static get is() {
return 'shopping-insights-app';
}
static get template() {
return getTemplate();
}
static get properties() {
return {
productInfo: Object,
priceInsightsInfo: Object,
isProductTrackable_: {
type: Boolean,
value: false,
},
isProductTracked_: {
type: Boolean,
value: false,
},
};
}
productInfo: ProductInfo;
priceInsightsInfo: PriceInsightsInfo;
private isProductTrackable_: boolean;
private isProductTracked_: boolean;
private shoppingApi_: BrowserProxy = BrowserProxyImpl.getInstance();
constructor() {
super();
ColorChangeUpdater.forDocument().start();
}
override async ready() {
super.ready();
const {productInfo} = await this.shoppingApi_.getProductInfoForCurrentUrl();
this.productInfo = productInfo;
const {priceInsightsInfo} =
await this.shoppingApi_.getPriceInsightsInfoForCurrentUrl();
this.priceInsightsInfo = priceInsightsInfo;
const {eligible} = await this.shoppingApi_.isShoppingListEligible();
const {tracked} =
await this.shoppingApi_.getPriceTrackingStatusForCurrentUrl();
this.isProductTracked_ = tracked;
this.isProductTrackable_ =
eligible && (priceInsightsInfo.clusterId !== BigInt(0));
}
override connectedCallback() {
super.connectedCallback();
// Push showInsightsSidePanelUI() callback to the event queue to allow
// deferred rendering to take place.
listenOnce(this.$.insightsContainer, 'dom-change', () => {
setTimeout(() => this.shoppingApi_.showInsightsSidePanelUi(), 0);
});
}
private getRangeDescription_(info: PriceInsightsInfo): string {
const lowPrice: string = info.typicalLowPrice;
const highPrice: string = info.typicalHighPrice;
if (info.hasMultipleCatalogs) {
return lowPrice === highPrice ?
loadTimeData.getStringF('rangeMultipleOptionsOnePrice', lowPrice) :
loadTimeData.getStringF('rangeMultipleOptions', lowPrice, highPrice);
}
return lowPrice === highPrice ?
loadTimeData.getStringF('rangeSingleOptionOnePrice', lowPrice) :
loadTimeData.getStringF('rangeSingleOption', lowPrice, highPrice);
}
private getHistoryTitle_(info: PriceInsightsInfo): string {
return loadTimeData.getString(
info.hasMultipleCatalogs ? 'historyTitleMultipleOptions' :
'historyTitleSingleOption');
}
}
declare global {
interface HTMLElementTagNameMap {
'shopping-insights-app': ShoppingInsightsAppElement;
}
}
customElements.define(
ShoppingInsightsAppElement.is, ShoppingInsightsAppElement);