import NOTION_ICONS from "../../common/notion-icons.mjs";
import utils from "../../common/utils.mjs";
import notion from "../../notion.app.mjs";
import base from "../common/base-page-builder.mjs";
import pick from "lodash-es/pick.js";
export default {
  ...base,
  key: "notion-create-page-from-database",
  name: "Create Page from Data Source",
  description: "Create a page from a data source. [See the documentation](https://developers.notion.com/reference/post-page)",
  version: "1.1.0",
  annotations: {
    destructiveHint: false,
    openWorldHint: true,
    readOnlyHint: false,
  },
  type: "action",
  props: {
    notion,
    parentDataSource: {
      propDefinition: [
        notion,
        "dataSourceId",
      ],
      label: "Parent Data Source ID",
      description: "Select a parent data source or provide a data source ID",
      reloadProps: true,
    },
    Name: {
      type: "string",
      label: "Name",
      description: "The name of the page. Use this only if the data source has a `title` property named `Name`. Otherwise, use the `Properties` prop below to set the title property.",
      optional: true,
    },
    propertyTypes: {
      propDefinition: [
        notion,
        "propertyTypes",
        (c) => ({
          parentId: c.parentDataSource,
          parentType: "data_source",
        }),
      ],
      description: "Select one or more page properties. Willl override properties set in the `Properties` prop below.",
      reloadProps: true,
    },
    properties: {
      type: "object",
      label: "Properties",
      description: "The values of the page's properties. The schema must match the parent data source's properties. [See the documentation](https://developers.notion.com/reference/property-object) for information on various property types. Example: `{ \"Tags\": [ \"tag1\" ], \"Link\": \"https://pipedream.com\" }`",
      optional: true,
    },
    icon: {
      type: "string",
      label: "Icon Emoji",
      description: "Page Icon [Emoji](https://developers.notion.com/reference/emoji-object)",
      options: NOTION_ICONS,
      optional: true,
    },
    cover: {
      type: "string",
      label: "Cover URL",
      description: "Cover [External URL](https://developers.notion.com/reference/file-object#external-file-objects)",
      optional: true,
    },
    alert: {
      type: "alert",
      alertType: "info",
      content: "This action will create an empty page by default. To add content, use the `Page Content` prop below.",
    },
    pageContent: {
      propDefinition: [
        notion,
        "pageContent",
      ],
    },
  },
  async additionalProps() {
    const { properties } = await this.notion.retrieveDataSource(this.parentDataSource);
    const selectedProperties = pick(properties, this.propertyTypes);
    return this.buildAdditionalProps({
      properties: selectedProperties,
    });
  },
  methods: {
    ...base.methods,
    
    buildPage(parentDataSource) {
      this.properties = utils.parseObject(this.properties);
      const properties = this.buildPageProperties(parentDataSource.properties);
      const propertiesArray = [];
      for (const property of Object.values(parentDataSource.properties)) {
        if (properties[property.id]) {
          propertiesArray.push({
            label: property.name,
            type: property.type,
            value: this[property.name] || this.properties[property.name],
          });
        }
      }
      return propertiesArray;
    },
  },
  async run({ $ }) {
    const parentPage = await this.notion.retrieveDataSource(this.parentDataSource);
    const properties = await this.buildPage(parentPage);
    const response = await this.buildPageFromDataSource({
      pageContent: this.pageContent,
      parentDataSourceId: this.parentDataSource,
      properties,
      icon: this.icon,
      cover: this.cover,
    });
    $.export("$summary", "Created page successfully");
    return response;
  },
};