Задать вопрос
  • React hook form как изменить атрибут name?

    @dima89e Автор вопроса
    Aetae, как это сделать например?
    Написано
  • VSCode no source control providers registered?

    @dima89e Автор вопроса
    Araya, я уже нагуглил и нашел
    Написано
  • Laravel в чем ошибка?

    @dima89e Автор вопроса
    как установить то? я на windows если что
    Написано
  • Как зафиксировать первую колонку на CSS?

    @dima89e
    <div class="container">
        <div class="data">
            <div class="fixed">Данные</div>
            <div>1</div>
            <div>2</div>
            <div>3</div>
            <div>4</div>
            <div>5</div>
            <div>6</div>
            <div>7</div>
            <div>8</div>
            <div>9</div>
            <div>10</div>
            <div>11</div>
            <div>12</div>
            <div>13</div>
            <div>14</div>
            <div>15</div>
        </div>
    </div>


    .container {
                display: flex;
                overflow-x: auto; 
                min-width: 100%; 
                border: 1px solid #ccc; 
            }
    
            .data {
                display: flex;
                min-width: 100%; 
            }
    
            .fixed {
                min-width: 100px; 
                background: lightgray; 
                position: sticky; 
                left: 0; 
                z-index: 1; 
                height: 100vh; 
            }
    
            .data > div {
                width: 100px; 
                border: 1px solid #ccc; 
                padding: 10px; 
                box-sizing: border-box; 
            }
    Написано
  • Как собрать статистику по реакциям под постами в Telegram канале?

    @dima89e
    Как-то так
    from telethon import TelegramClient
    from telethon.tl import types
    
    # Замените 'api_id', 'api_hash', 'phone' на свои данные
    api_id = 'YOUR_API_ID'
    api_hash = 'YOUR_API_HASH'
    phone = 'YOUR_PHONE_NUMBER'
    
    # Имя канала
    channel = 't.me/your_channel_name'
    
    async def main():
        async with TelegramClient('session_name', api_id, api_hash) as client:
            # Получаем информацию о канале
            entity = await client.get_entity(channel)
    
            # Получаем последние сообщения из канала
            async for message in client.iter_messages(entity, limit=100):
                if message.reactions:
                    print(f'Message ID: {message.id}')
                    print(f'Text: {message.message}')
                    print(f'Reactions: {message.reactions}')
    
    import asyncio
    asyncio.run(main())
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    Анатолий Медведев, я вообще в яндекс браузере
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    в обоих предлагается у меня
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    Анатолий Медведев, не знаю в каком ты браузере, но в моем в обоих предлагается автозаполнение
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    Сергей delphinpro, да, в select заметил баг с этим
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    Сергей delphinpro, ну а как тогда убрать эту маску?
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    Сергей delphinpro, в таком случае вообще лучше убрать этот атрибут name, а если уж на сервер php отправлять, то через js лучше постараться
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    tgarl, name="mail" поставь так, у меня работает
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    tgarl, может стилизовать как-то это можно и display: none добавить...
    Написано
  • HTML как убрать эти подсказки браузера?

    @dima89e Автор вопроса
    это самому пользователю настройки указывать надо
    Написано
  • React hook form как отследить изменения?

    @dima89e Автор вопроса
    szQocks, спасибо большое, сработало!
    Написано
  • React hook form как отследить изменения?

    @dima89e Автор вопроса
    Александр, а вообще нужно чтоб daysCountInMonth менялся при изменении year и month в birthdateinput

    // page.tsx
    'use client'
    
    import { zodResolver } from '@hookform/resolvers/zod'
    import {
    	Button,
    	FormControl,
    	FormControlLabel,
    	FormLabel,
    	InputLabel,
    	Radio,
    	RadioGroup
    } from '@mui/material'
    import { useEffect, useState } from 'react'
    import { SubmitHandler, useForm } from 'react-hook-form'
    import BirthDateInput from '@/shared/components/ui/BirthDateInput'
    import EmailInput from '@/shared/components/ui/EmailInput'
    import PasswordInput from '@/shared/components/ui/PasswordInput'
    import StrokeInput from '@/shared/components/ui/StrokeInput'
    import TelInput from '@/shared/components/ui/TelInput'
    import { EMAILDOMAINS } from '@/shared/constants/forms.constants'
    import { registerSchema } from '@/shared/schemas/register.schema'
    import { IRegisterForm } from '@/shared/types/auth.types'
    
    const RegisterPage = () => {
    	const {
    		register,
    		handleSubmit,
    		reset,
    		setValue,
    		control,
    		setError,
    		getValues,
    		formState: { errors }
    	} = useForm<IRegisterForm>({
    		resolver: zodResolver(registerSchema)
    	})
    
    	useEffect(() => {
    		console.log('changed value ', getValues('birthdate'))
    	}, [
    		getValues,
    		getValues('birthdate'),
    		getValues('birthdate')?.year,
    		getValues('birthdate')?.month,
    		getValues('birthdate')?.day
    	]) // не отслеивается изменение
    
    	const [emailValue, setEmailValue] = useState('')
    
    	const onSubmit: SubmitHandler<IRegisterForm> = (data, e) => {
    		e?.preventDefault()
    		console.log('submit ', data)
    	}
    
    	return (
    		<div className='max-w-[600px] mx-auto shadow-normal p-5 mt-10 mb-10'>
    			<form onSubmit={handleSubmit(onSubmit)}>
    				<h2 className='text-center text-2xl font-bold mb-10'>
    					Создание почтового ящика
    				</h2>
    
    				<div className='flex flex-col gap-4'>
    					<div className='flex gap-4'>
    						<StrokeInput
    							label='Имя'
    							error={!!errors.name}
    							helperText={errors.name?.message}
    							{...register('name')}
    						/>
    						<StrokeInput
    							label='Фамилия'
    							error={!!errors.lastName}
    							helperText={errors.lastName?.message}
    							{...register('lastName')}
    						/>
    					</div>
    
    					<div>
    						<InputLabel>Дата рождения</InputLabel>
    						<BirthDateInput
    							errors={{
    								day: errors.birthdate?.day,
    								month: errors.birthdate?.month,
    								year: errors.birthdate?.year
    							}}
    							register={register}
    							control={control}
    						/>
    					</div>
    
    					<FormControl>
    						<FormLabel id='demo-row-radio-buttons-group-label'>Пол</FormLabel>
    						<RadioGroup
    							row
    							aria-labelledby='demo-row-radio-buttons-group-label'
    							name='row-radio-buttons-group'
    						>
    							<FormControlLabel
    								value='female'
    								control={<Radio />}
    								label='Мужской'
    							/>
    							<FormControlLabel
    								value='male'
    								control={<Radio />}
    								label='Женский'
    							/>
    						</RadioGroup>
    					</FormControl>
    
    					<div>
    						<InputLabel>Имя ящика</InputLabel>
    						<EmailInput
    							inputType='register'
    							domains={EMAILDOMAINS.domains}
    							defaultDomainValue={EMAILDOMAINS.defaultValue}
    							value={emailValue}
    							setValue={setEmailValue}
    						/>
    					</div>
    
    					<div>
    						<InputLabel>Номер телефона</InputLabel>
    						<TelInput />
    					</div>
    
    					<div>
    						<InputLabel>Пароль</InputLabel>
    						<PasswordInput />
    					</div>
    
    					<Button
    						type='submit'
    						variant='contained'
    						sx={{ mt: 3 }}
    					>
    						Создать
    					</Button>
    				</div>
    			</form>
    		</div>
    	)
    }
    export default RegisterPage
    
    
    // BirthDateInput.tsx
    'use client'
    
    import { MenuItem } from '@mui/material'
    import React, { useMemo } from 'react'
    import SelectRoot from '@/shared/components/ui/SelectRoot'
    import ErrorText from './ErrorText'
    import { BIRTHDATEMONTHES } from '@/shared/constants/forms.constants'
    import { formatDaysArr } from '@/shared/lib/format-days-arr'
    import { formatYearsArr } from '@/shared/lib/format-years-arr'
    
    export interface IBirthDateInputValues {
    	day: string
    	month: string
    	year: string
    }
    
    interface IBirthDateInputProps {
    	errors: {
    		day?: { message?: string }
    		month?: { message?: string }
    		year?: { message?: string }
    	}
    	register: any
    	control: any
    	values?: IBirthDateInputValues
    	setValues?: (values: IBirthDateInputValues) => void
    }
    
    const BirthDateInput: React.FC<IBirthDateInputProps> = ({
    	errors,
    	register,
    	values = {
    		day: '',
    		month: '',
    		year: ''
    	}
    }) => {
    	const { day, month, year } = values
    
    	const daysCountInMonth = useMemo(() => {
    		console.log('FORMATDASYARR ', values)
    		return formatDaysArr(Number(year), Number(month))
    	}, [month, values, year])
    
    	return (
    		<div className='flex flex-col'>
    			<div className='flex'>
    				<SelectRoot
    					placeholder='День'
    					defaultValue={day}
    					error={!!errors?.day}
    					{...register('birthdate.day')}
    				>
    					{[...Array(daysCountInMonth)].map((_, index) => (
    						<MenuItem
    							key={index}
    							value={(index + 1).toString()}
    						>
    							{index + 1}
    						</MenuItem>
    					))}
    				</SelectRoot>
    
    				<SelectRoot
    					fullWidth
    					placeholder='Месяц'
    					defaultValue={month}
    					{...register('birthdate.month')}
    					error={!!errors?.month}
    				>
    					{BIRTHDATEMONTHES.map((item, index) => (
    						<MenuItem
    							key={item}
    							value={(index + 1).toString()}
    						>
    							{item}
    						</MenuItem>
    					))}
    				</SelectRoot>
    
    				<SelectRoot
    					placeholder='Год'
    					defaultValue={year}
    					{...register('birthdate.year')}
    					error={!!errors?.year}
    				>
    					{formatYearsArr().map(item => (
    						<MenuItem
    							key={item}
    							value={item.toString()}
    						>
    							{item}
    						</MenuItem>
    					))}
    				</SelectRoot>
    			</div>
    
    			{(errors?.day || errors?.month || errors?.year) && (
    				<ErrorText>
    					{errors?.day?.message ||
    						errors?.month?.message ||
    						errors?.year?.message ||
    						'Заполните все поля даты рождения'}
    				</ErrorText>
    			)}
    		</div>
    	)
    }
    
    export default BirthDateInput
    Написано
  • React hook form как отследить изменения?

    @dima89e Автор вопроса
    Александр, там мне надо 3 select изменения отследить и судь вопроса не в этом была
    Написано
  • React hook form как отследить изменения?

    @dima89e Автор вопроса
    Александр, что значит зачем? нужно отследить событие select, а пока что я хочу по простому через useeffect хотя бы что-то с этим сделать
    Написано