// Copyright (C) 2023 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

import m from 'mithril';
import {assertTrue} from '../../base/logging';
import {exists} from '../../base/utils';
import {getSlice, SliceDetails} from '../../components/sql_utils/slice';
import {asSliceSqlId} from '../../components/sql_utils/core_types';
import {Engine} from '../../trace_processor/engine';
import {TrackEventDetailsPanel} from '../../public/details_panel';
import {TrackEventSelection} from '../../public/selection';

export class ScreenshotDetailsPanel implements TrackEventDetailsPanel {
  private sliceDetails?: SliceDetails;

  constructor(private readonly engine: Engine) {}

  async load(selection: TrackEventSelection) {
    this.sliceDetails = await getSlice(
      this.engine,
      asSliceSqlId(selection.eventId),
    );
  }

  render() {
    if (
      !exists(this.sliceDetails) ||
      !exists(this.sliceDetails.args) ||
      this.sliceDetails.args.length == 0
    ) {
      return m('h2', 'Loading Screenshot');
    }
    assertTrue(this.sliceDetails.args[0].key == 'screenshot.jpg_image');
    return m(
      '.screenshot-panel',
      m('img', {
        src: 'data:image/png;base64, ' + this.sliceDetails.args[0].displayValue,
      }),
    );
  }
}
