/*
 * Tencent is pleased to support the open source community by making
 * Hippy available.
 *
 * Copyright (C) 2017-2019 THL A29 Limited, a Tencent company.
 * All rights reserved.
 *
 * 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 React from 'react';
import { Fiber } from '@hippy/react-reconciler';
import { LayoutableProps } from '../types';
import { callUIFunction } from '../modules/ui-manager-module';
import Element from '../dom/element-node';

export interface CollapsePullHeaderOptions {
  // time left to hide pullHeader after collapsePullHeader() is called, unit is ms
  time?: number,
}

export interface PullHeaderProps extends LayoutableProps {
  style?: HippyTypes.StyleProp;
  /**
   * Trigger when release the finger after pulling distance larger than the content height
   */
  onHeaderReleased?: () => void;

  /**
   * Trigger when pulling
   *
   * @param {Object} evt - Event data
   * @param {number} evt.contentOffset - Dragging distance
   */
  onHeaderPulling?: (evt: HippyTypes.PullingEvent) => void;
}

export class PullHeader extends React.Component<PullHeaderProps, {}> {
  private instance: Element | Fiber | HTMLDivElement | null = null;

  /**
   * Expand the PullView and display the content
   */
  public expandPullHeader() {
    callUIFunction(this.instance as Fiber, 'expandPullHeader', []);
  }

  /**
   * Collapse the PullView and hide the content
   * @param {CollapsePullHeaderOptions} [options] - additional config for pull header
   */
  public collapsePullHeader(options: CollapsePullHeaderOptions) {
    if (typeof options !== 'undefined') {
      callUIFunction(this.instance as Element, 'collapsePullHeaderWithOptions', [options]);
    } else {
      callUIFunction(this.instance as Element, 'collapsePullHeader', []);
    }
  }

  public render() {
    const { children, style, ...nativeProps } = this.props;
    return (
      <div
        nativeName="PullHeaderView"
        ref={(ref) => {
          this.instance = ref;
        }}
        // @ts-ignore
        style={style}
        {...nativeProps}
      >
        { children }
      </div>
    );
  }
}

export default PullHeader;
