import React from 'react';
import { Meta, Story } from '@storybook/react';
import Memori, { Props } from './index';

const meta: Meta = {
  title: 'General/Functionalities',
  component: Memori,
  argTypes: {
    AZURE_COGNITIVE_SERVICES_TTS_KEY: {
      control: {
        type: 'text',
      },
    },
  },
  parameters: {
    controls: { expanded: true },
    layout: 'fullscreen',
  },
};

export default meta;

const Template: Story<Props> = args => <Memori {...args} />;

export const WithInitialContextAndQuestion = Template.bind({});
WithInitialContextAndQuestion.args = {
  ownerUserName: 'nzambello',
  memoriName: 'Nicola',
  tenantID: 'www.aisuru.com',
  engineURL: 'https://engine.memori.ai',
  apiURL: 'https://backend.memori.ai',
  baseURL: 'https://www.aisuru.com',
  uiLang: 'IT',
  spokenLang: 'IT',
  enableAudio: true,
  autoStart: true,
  initialQuestion: 'Ciao',
  context: { STORYBOOK: 'true' },
};

export const WithInitialContextAndQuestionFromIntegration = Template.bind({});
WithInitialContextAndQuestionFromIntegration.args = {
  ownerUserName: 'nzambello',
  memoriName: 'Nicola',
  tenantID: 'www.aisuru.com',
  engineURL: 'https://engine.memori.ai',
  apiURL: 'https://backend.memori.ai',
  baseURL: 'https://www.aisuru.com',
  uiLang: 'IT',
  spokenLang: 'IT',
  enableAudio: true,
  autoStart: true,
  integration: {
    integrationID: 'test',
    customData: JSON.stringify({
      initialQuestion: 'Ciao',
      contextVars: 'STORYBOOK:true',
    }),
  },
};

export const WithPreviousSession = Template.bind({});
WithPreviousSession.args = {
  ownerUserName: 'nzambello',
  memoriName: 'Nicola',
  tenantID: 'www.aisuru.com',
  engineURL: 'https://engine.memori.ai',
  apiURL: 'https://backend.memori.ai',
  baseURL: 'https://www.aisuru.com',
  sessionID: '1234567890',
  uiLang: 'IT',
  spokenLang: 'IT',
};

export const WithChatHistory = Template.bind({});
WithChatHistory.args = {
  ownerUserName: 'nzambello',
  memoriName: 'Nicola',
  tenantID: 'www.aisuru.com',
  engineURL: 'https://engine.memori.ai',
  apiURL: 'https://backend.memori.ai',
  baseURL: 'https://www.aisuru.com',
  uiLang: 'IT',
  spokenLang: 'IT',
  showChatHistory: true,
};

export const WithUploadNoTotalPayloadLimit = Template.bind({});
WithUploadNoTotalPayloadLimit.args = {
  ownerUserName: 'nzambello',
  memoriName: 'Nicola',
  tenantID: 'www.aisuru.com',
  engineURL: 'https://engine.memori.ai',
  apiURL: 'https://backend.memori.ai',
  baseURL: 'https://www.aisuru.com',
  uiLang: 'IT',
  spokenLang: 'IT',
  enableAudio: true,
  showUpload: true,
};

export const WithMaxTextareaCharacters = Template.bind({});
WithMaxTextareaCharacters.args = {
  ownerUserName: 'nzambello',
  memoriName: 'Nicola',
  tenantID: 'www.aisuru.com',
  engineURL: 'https://engine.memori.ai',
  apiURL: 'https://backend.memori.ai',
  baseURL: 'https://www.aisuru.com',
  uiLang: 'IT',
  spokenLang: 'IT',
  enableAudio: true,
  showUpload: true,
  maxTextareaCharacters: 500,
};

export const WithPrivateAgent = Template.bind({});
WithPrivateAgent.args = {
  memoriName: 'Test Private',
  ownerUserName: 'Andrea-Patini',
  memoriID: 'c58cd5f9-43c4-4a3b-9fb6-56aedf58ff7a',
  ownerUserID: '91dbc9ba-b684-4fbe-9828-b5980af6cda9',
  tenantID: 'aisuru-staging.aclambda.online',
  apiURL: 'https://backend-staging.memori.ai/api/v2',
  engineURL: 'https://engine-staging.memori.ai/memori/v2',
  baseURL: 'https://aisuru-staging.aclambda.online',
  uiLang: 'EN',
  spokenLang: 'IT',
  layout: 'FULLPAGE',
  multilingual: true,
  showSettings: true,
  showShare: true,
  integrationID: '19f95abe-3493-4568-971d-14471480e5bc',
};

// PII detection: only via integration customData (layout as object with piiDetection). Try sending an email or IBAN to see the error bubble.
const piiDetectionConfig = {
  enabled: true,
  rules: [
    {
      id: 'email',
      label: { it: 'Email', en: 'Email' },
      pattern: '\\b[A-Za-z0-9._%+\\-]+@[A-Za-z0-9.\\-]+\\.[A-Za-z]{2,}\\b',
      message: {
        it: 'Il messaggio contiene un indirizzo email.',
        en: 'The message contains an email address.',
      },
    },
    {
      id: 'iban',
      label: { it: 'IBAN', en: 'IBAN' },
      pattern:
        '\\b[A-Z]{2}\\d{2}(?:[ ]?[A-Z0-9]{4}){3,7}(?:[ ]?[A-Z0-9]{1,4})?\\b',
      message: {
        it: 'Il messaggio contiene un codice IBAN.',
        en: 'The message contains an IBAN code.',
      },
    },
  ],
  errorMessage: {
    it: 'Il messaggio contiene dati personali o sensibili.',
    en: 'The message contains personal or sensitive data.',
  },
};

/** Story: PII detection via integration config only. Send a message containing an email (e.g. test@example.com) or IBAN to see the red error bubble. */
export const WithPiiDetection = Template.bind({});
WithPiiDetection.args = {
  memoriName: 'Layout Storybook',
  ownerUserName: 'andrea.patini',
  memoriID: 'ae20fc5a-cc15-4db9-b7dd-2cd4a621b85e',
  ownerUserID: '91dbc9ba-b684-4fbe-9828-b5980af6cda9',
  tenantID: 'aisuru-staging.aclambda.online',
  engineURL: 'https://engine-staging.memori.ai/memori/v2',
  apiURL: 'https://backend-staging.memori.ai/api/v2',
  uiLang: 'IT',
  spokenLang: 'IT',
  integration: {
    integrationID: 'pii-demo',
    customData: JSON.stringify({
      layout: {
        name: 'DEFAULT',
        piiDetection: piiDetectionConfig,
      },
      lang: 'it',
    }),
  },
};

export const WithLocalNats = Template.bind({});
WithLocalNats.args = {
  memoriName: 'test324',
  ownerUserName: 'andrea.patini',
  memoriID: 'd661a9ca-e907-4396-a986-5095ccd582d6',
  ownerUserID: '69fcc557-9cb6-4e5e-b8ab-140cff975492',
  tenantID: 'localhost:3000',
  engineURL: 'http://localhost:7778/memori/v2',
  apiURL: 'http://localhost:7778/api/v2',
  baseURL: 'http://localhost:3000',
  layout: 'FULLPAGE',
  uiLang: 'IT',
  spokenLang: 'IT',
  integrationID: 'ee1c3d98-7819-4506-ba28-818e79ba86cb',
};

export const WithFunctionalities = Template.bind({});
WithFunctionalities.args = {
  memoriName: 'test324',
  ownerUserName: 'andrea.patini',
  memoriID: 'd661a9ca-e907-4396-a986-5095ccd582d6',
  ownerUserID: '69fcc557-9cb6-4e5e-b8ab-140cff975492',
  tenantID: 'localhost:3000',
  engineURL: 'http://localhost:7778/memori/v2',
  apiURL: 'http://localhost:7778/api/v2',
  baseURL: 'http://localhost:3000',
  layout: 'FULLPAGE',
  uiLang: 'IT',
  spokenLang: 'IT',
  integrationID: 'ee1c3d98-7819-4506-ba28-818e79ba86cb',
};
