UNPKG

@nlabs/gothamjs

Version:
159 lines (158 loc) 13.6 kB
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"}