// Dependencies import { nsMerge } from 'shared/utils.mjs' import { ns as authNs } from 'shared/components/wrappers/auth/index.mjs' import { designMeasurements } from 'shared/utils.mjs' // Hooks import { useTranslation } from 'next-i18next' import { useLoadingStatus } from 'shared/hooks/use-loading-status.mjs' // Components import { SetPicker, ns as setsNs } from 'shared/components/account/sets.mjs' import { Tabs, Tab } from 'shared/components/tabs.mjs' import { MeasiesEditor } from './editor.mjs' import { Popout } from 'shared/components/popout/index.mjs' export const ns = nsMerge(authNs, setsNs) const tabNames = ['account:chooseASet', 'editCurrentMeasies'] export const MeasiesView = ({ design, Design, settings, update, missingMeasurements, setView }) => { const { t } = useTranslation(['workbench']) const { setLoadingStatus, LoadingStatus } = useLoadingStatus() const tabs = tabNames.map((n) => t(n)).join(',') const loadMeasurements = (set) => { update.settings([ [['measurements'], designMeasurements(Design, set.measies)], [['units'], set.imperial ? 'imperial' : 'metric'], ]) setView('draft') setLoadingStatus([true, 'appliedMeasies', true, true]) } return (

{t('account:measurements')}

{missingMeasurements ? (
{t('weLackSomeMeasies', { nr: missingMeasurements.length })}
    {missingMeasurements.map((m, i) => (
  1. {t(`measurements:${m}`)}
  2. ))}

{t('youCanPickOrEnter')}

) : ( {t('measiesOk')} )}
) }