@nlabs/gothamjs
Version:
Platform
159 lines (158 loc) • 13.6 kB
JavaScript
import { jsx as _jsx } from "react/jsx-runtime";
import React from 'react';
import { FormProvider, useForm } from 'react-hook-form';
import { I18nextProvider, initReactI18next } from 'react-i18next';
import { i18n } from '../../i18n/index.js';
import { gothamColors } from '../../utils/colorUtils.js';
import { TextField } from './TextField.js';
const meta = {
argTypes: {
borderColor: {
control: 'select',
defaultValue: 'secondary',
description: 'The color of the border',
options: gothamColors
},
borderType: {
control: 'select',
defaultValue: 'underline',
description: 'The type of border of the text field',
options: [
'solid',
'rounded',
'none',
'underline'
]
},
hasError: {
control: 'boolean',
defaultValue: false,
description: 'Whether the text field has an error'
},
labelColor: {
control: 'select',
defaultValue: 'white',
description: 'The color of the label',
options: gothamColors
},
multiline: {
control: 'boolean',
defaultValue: false,
description: 'Whether the text field is multiline'
},
pattern: {
control: 'text',
description: 'The pattern of the text field'
},
placeholderColor: {
control: 'select',
defaultValue: 'secondary',
description: 'The color of the placeholder',
options: gothamColors
},
rows: {
control: 'number',
defaultValue: 1,
description: 'The number of rows of the text field'
},
textColor: {
control: 'select',
defaultValue: 'white',
description: 'The color of the text',
options: gothamColors
}
},
component: TextField,
decorators: [
(Story)=>{
const methods = useForm();
// Initialize i18n for Storybook
const storyI18n = i18n.createInstance();
storyI18n.use(initReactI18next).init({
resources: {
en: {
translation: {
'Textfield placeholder': 'Textfield placeholder',
'Enter email address': 'Enter email address',
'Description': 'Description'
}
}
},
lng: 'en',
fallbackLng: 'en',
interpolation: {
escapeValue: false
}
});
return /*#__PURE__*/ _jsx(I18nextProvider, {
i18n: storyI18n,
children: /*#__PURE__*/ _jsx(FormProvider, {
...methods,
children: /*#__PURE__*/ _jsx("div", {
className: "p-4 max-w-md",
children: /*#__PURE__*/ _jsx(Story, {})
})
})
});
}
],
parameters: {
backgrounds: {
default: 'light',
values: [
{
name: 'light',
value: '#ffffff'
},
{
name: 'dark',
value: '#1a1a1a'
}
]
},
layout: 'centered'
},
title: 'Components/TextField'
};
export default meta;
export const Default = {
args: {
borderColor: 'secondary',
borderType: 'underline',
disabled: false,
error: false,
label: 'Default TextField',
labelColor: 'black',
name: 'default',
placeholder: 'Textfield placeholder',
placeholderColor: 'secondary',
required: true
}
};
export const Multiline = {
args: {
borderColor: 'secondary',
borderType: 'solid',
disabled: false,
error: false,
label: 'Default TextField',
labelColor: 'black',
multiline: true,
name: 'default',
placeholder: 'Description',
placeholderColor: 'secondary',
required: true,
rows: 1,
textColor: 'black'
}
};
export const WithPattern = {
args: {
disabled: false,
label: 'Email TextField',
name: 'email',
pattern: '[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,}$',
placeholder: 'Enter email address'
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/gothamjs/src/components/TextField/TextField.stories.tsx"],"sourcesContent":["import React from 'react';\nimport {FormProvider, useForm} from 'react-hook-form';\nimport {I18nextProvider, initReactI18next} from 'react-i18next';\nimport {i18n} from '../../i18n/index.js';\n\nimport {gothamColors} from '../../utils/colorUtils.js';\nimport {TextField} from './TextField.js';\n\nimport type {Meta, StoryObj} from '@nlabs/lex/storybook';\n\nconst meta: Meta<typeof TextField> = {\n  argTypes: {\n    borderColor: {\n      control: 'select',\n      defaultValue: 'secondary',\n      description: 'The color of the border',\n      options: gothamColors\n    },\n    borderType: {\n      control: 'select',\n      defaultValue: 'underline',\n      description: 'The type of border of the text field',\n      options: ['solid', 'rounded', 'none', 'underline']\n    },\n    hasError: {\n      control: 'boolean',\n      defaultValue: false,\n      description: 'Whether the text field has an error'\n    },\n    labelColor: {\n      control: 'select',\n      defaultValue: 'white',\n      description: 'The color of the label',\n      options: gothamColors\n    },\n    multiline: {\n      control: 'boolean',\n      defaultValue: false,\n      description: 'Whether the text field is multiline'\n    },\n    pattern: {\n      control: 'text',\n      description: 'The pattern of the text field'\n    },\n    placeholderColor: {\n      control: 'select',\n      defaultValue: 'secondary',\n      description: 'The color of the placeholder',\n      options: gothamColors\n    },\n    rows: {\n      control: 'number',\n      defaultValue: 1,\n      description: 'The number of rows of the text field'\n    },\n    textColor: {\n      control: 'select',\n      defaultValue: 'white',\n      description: 'The color of the text',\n      options: gothamColors\n    }\n  },\n  component: TextField,\n  decorators: [\n    (Story) => {\n      const methods = useForm();\n\n      // Initialize i18n for Storybook\n      const storyI18n = i18n.createInstance();\n      storyI18n\n        .use(initReactI18next)\n        .init({\n          resources: {\n            en: {\n              translation: {\n                'Textfield placeholder': 'Textfield placeholder',\n                'Enter email address': 'Enter email address',\n                'Description': 'Description'\n              }\n            }\n          },\n          lng: 'en',\n          fallbackLng: 'en',\n          interpolation: {\n            escapeValue: false,\n          },\n        });\n\n      return (\n        <I18nextProvider i18n={storyI18n}>\n          <FormProvider {...methods}>\n            <div className=\"p-4 max-w-md\">\n              <Story />\n            </div>\n          </FormProvider>\n        </I18nextProvider>\n      );\n    }\n  ],\n  parameters: {\n    backgrounds: {\n      default: 'light',\n      values: [\n        {name: 'light', value: '#ffffff'},\n        {name: 'dark', value: '#1a1a1a'}\n      ]\n    },\n    layout: 'centered'\n  },\n  title: 'Components/TextField'\n};\n\nexport default meta;\ntype Story = StoryObj<typeof TextField>;\n\nexport const Default: Story = {\n  args: {\n    borderColor: 'secondary',\n    borderType: 'underline',\n    disabled: false,\n    error: false,\n    label: 'Default TextField',\n    labelColor: 'black',\n    name: 'default',\n    placeholder: 'Textfield placeholder',\n    placeholderColor: 'secondary',\n    required: true\n  }\n};\n\nexport const Multiline: Story = {\n  args: {\n    borderColor: 'secondary',\n    borderType: 'solid',\n    disabled: false,\n    error: false,\n    label: 'Default TextField',\n    labelColor: 'black',\n    multiline: true,\n    name: 'default',\n    placeholder: 'Description',\n    placeholderColor: 'secondary',\n    required: true,\n    rows: 1,\n    textColor: 'black'\n  }\n};\n\nexport const WithPattern: Story = {\n  args: {\n    disabled: false,\n    label: 'Email TextField',\n    name: 'email',\n    pattern: '[a-z0-9._%+-]+@[a-z0-9.-]+\\\\.[a-z]{2,}$',\n    placeholder: 'Enter email address'\n  }\n};"],"names":["React","FormProvider","useForm","I18nextProvider","initReactI18next","i18n","gothamColors","TextField","meta","argTypes","borderColor","control","defaultValue","description","options","borderType","hasError","labelColor","multiline","pattern","placeholderColor","rows","textColor","component","decorators","Story","methods","storyI18n","createInstance","use","init","resources","en","translation","lng","fallbackLng","interpolation","escapeValue","div","className","parameters","backgrounds","default","values","name","value","layout","title","Default","args","disabled","error","label","placeholder","required","Multiline","WithPattern"],"mappings":";AAAA,OAAOA,WAAW,QAAQ;AAC1B,SAAQC,YAAY,EAAEC,OAAO,QAAO,kBAAkB;AACtD,SAAQC,eAAe,EAAEC,gBAAgB,QAAO,gBAAgB;AAChE,SAAQC,IAAI,QAAO,sBAAsB;AAEzC,SAAQC,YAAY,QAAO,4BAA4B;AACvD,SAAQC,SAAS,QAAO,iBAAiB;AAIzC,MAAMC,OAA+B;IACnCC,UAAU;QACRC,aAAa;YACXC,SAAS;YACTC,cAAc;YACdC,aAAa;YACbC,SAASR;QACX;QACAS,YAAY;YACVJ,SAAS;YACTC,cAAc;YACdC,aAAa;YACbC,SAAS;gBAAC;gBAAS;gBAAW;gBAAQ;aAAY;QACpD;QACAE,UAAU;YACRL,SAAS;YACTC,cAAc;YACdC,aAAa;QACf;QACAI,YAAY;YACVN,SAAS;YACTC,cAAc;YACdC,aAAa;YACbC,SAASR;QACX;QACAY,WAAW;YACTP,SAAS;YACTC,cAAc;YACdC,aAAa;QACf;QACAM,SAAS;YACPR,SAAS;YACTE,aAAa;QACf;QACAO,kBAAkB;YAChBT,SAAS;YACTC,cAAc;YACdC,aAAa;YACbC,SAASR;QACX;QACAe,MAAM;YACJV,SAAS;YACTC,cAAc;YACdC,aAAa;QACf;QACAS,WAAW;YACTX,SAAS;YACTC,cAAc;YACdC,aAAa;YACbC,SAASR;QACX;IACF;IACAiB,WAAWhB;IACXiB,YAAY;QACV,CAACC;YACC,MAAMC,UAAUxB;YAEhB,gCAAgC;YAChC,MAAMyB,YAAYtB,KAAKuB,cAAc;YACrCD,UACGE,GAAG,CAACzB,kBACJ0B,IAAI,CAAC;gBACJC,WAAW;oBACTC,IAAI;wBACFC,aAAa;4BACX,yBAAyB;4BACzB,uBAAuB;4BACvB,eAAe;wBACjB;oBACF;gBACF;gBACAC,KAAK;gBACLC,aAAa;gBACbC,eAAe;oBACbC,aAAa;gBACf;YACF;YAEF,qBACE,KAAClC;gBAAgBE,MAAMsB;0BACrB,cAAA,KAAC1B;oBAAc,GAAGyB,OAAO;8BACvB,cAAA,KAACY;wBAAIC,WAAU;kCACb,cAAA,KAACd;;;;QAKX;KACD;IACDe,YAAY;QACVC,aAAa;YACXC,SAAS;YACTC,QAAQ;gBACN;oBAACC,MAAM;oBAASC,OAAO;gBAAS;gBAChC;oBAACD,MAAM;oBAAQC,OAAO;gBAAS;aAChC;QACH;QACAC,QAAQ;IACV;IACAC,OAAO;AACT;AAEA,eAAevC,KAAK;AAGpB,OAAO,MAAMwC,UAAiB;IAC5BC,MAAM;QACJvC,aAAa;QACbK,YAAY;QACZmC,UAAU;QACVC,OAAO;QACPC,OAAO;QACPnC,YAAY;QACZ2B,MAAM;QACNS,aAAa;QACbjC,kBAAkB;QAClBkC,UAAU;IACZ;AACF,EAAE;AAEF,OAAO,MAAMC,YAAmB;IAC9BN,MAAM;QACJvC,aAAa;QACbK,YAAY;QACZmC,UAAU;QACVC,OAAO;QACPC,OAAO;QACPnC,YAAY;QACZC,WAAW;QACX0B,MAAM;QACNS,aAAa;QACbjC,kBAAkB;QAClBkC,UAAU;QACVjC,MAAM;QACNC,WAAW;IACb;AACF,EAAE;AAEF,OAAO,MAAMkC,cAAqB;IAChCP,MAAM;QACJC,UAAU;QACVE,OAAO;QACPR,MAAM;QACNzB,SAAS;QACTkC,aAAa;IACf;AACF,EAAE"}