Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(DateInput): add placeholder prop #8168

Open
wants to merge 7 commits into
base: master
Choose a base branch
from

Conversation

EldarMuhamethanov
Copy link
Contributor

@EldarMuhamethanov EldarMuhamethanov commented Jan 20, 2025


  • Unit-тесты
  • e2e-тесты
  • Дизайн-ревью
  • Документация фичи
  • Release notes

Описание

Нужно добавить отображение placeholder - текст, который будет отображаться при пустом значении value

Изменения

  • Добавил свойство renderCustomValue, которое позволяет отрендерить кастомный текст в зависимости от значения в поле
  • Добавил скришоты, тесты нового функционала

Release notes

Улучшения

  • DateInput: добавлено свойство renderCustomValue, которое позволяет отрендерить кастомный текст в зависимости от значения в поле

@EldarMuhamethanov EldarMuhamethanov requested a review from a team January 20, 2025 08:58
@EldarMuhamethanov EldarMuhamethanov requested a review from a team as a code owner January 20, 2025 08:58
Copy link

codesandbox-ci bot commented Jan 20, 2025

This pull request is automatically built and testable in CodeSandbox.

To see build info of the built libraries, click here or the icon next to each commit SHA.

Copy link
Contributor

github-actions bot commented Jan 20, 2025

size-limit report 📦

Path Size
JS 392.68 KB (+0.09% 🔺)
JS (gzip) 119.06 KB (+0.06% 🔺)
JS (brotli) 97.92 KB (+0.08% 🔺)
JS import Div (tree shaking) 1.56 KB (0%)
CSS 344.9 KB (+0.26% 🔺)
CSS (gzip) 42.76 KB (+0.29% 🔺)
CSS (brotli) 34.04 KB (+0.09% 🔺)

Copy link
Contributor

github-actions bot commented Jan 20, 2025

e2e tests

Playwright Report

Copy link
Contributor

github-actions bot commented Jan 20, 2025

👀 Docs deployed

Commit 995627f

Copy link

codecov bot commented Jan 20, 2025

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 95.50%. Comparing base (d5629e8) to head (9200905).
Report is 2 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master    #8168      +/-   ##
==========================================
+ Coverage   95.49%   95.50%   +0.01%     
==========================================
  Files         403      403              
  Lines       11456    11460       +4     
  Branches     3781     3784       +3     
==========================================
+ Hits        10940    10945       +5     
+ Misses        516      515       -1     
Flag Coverage Δ
unittests 95.50% <100.00%> (+0.01%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

# Conflicts:
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-android-chromium-dark-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-android-chromium-light-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-ios-webkit-dark-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-ios-webkit-light-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-vkcom-chromium-dark-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-vkcom-chromium-light-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-vkcom-firefox-dark-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-vkcom-firefox-light-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-vkcom-webkit-dark-1-snap.png
#	packages/vkui/src/components/DateInput/__image_snapshots__/dateinput-vkcom-webkit-light-1-snap.png
Comment on lines 43 to 44
-webkit-user-select: none;
-moz-user-select: none;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
-webkit-user-select: none;
-moz-user-select: none;

автопрефиксер сам выставит

Comment on lines 104 to 107
/**
* Текст, который будет отображаться в пустом поле ввода
*/
placeholder?: string;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

placeholder всё же должен означать, что ничего не задано и быть тусклого цвета 🤔 сейчас placholder это считай это __.__.___

учитывая, что ребятам хочется значение по умолчанию, то тут нужен defaulValue куда нужно будет передать текущую дату (если рассматривать их задачу), а чтобы вместо даты был текст, нужен 2-ой параметр и тут два решения:

Graceful degradation – relativeTimeFormat

Note

Не везде поддерживается https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/formatToParts

const rtf = new Intl.RelativeTimeFormat('ru', { numeric: "auto" });
console.log(rtf.formatToParts(0, "second")[0].value);
type RelativeTimeFormat = { value: number, unit: "year" | "quarter" | "month" | "week" | "day" | "hour" | "minute" | "second" };

локаль берём из контекста const { locale } = useConfigProvider();

Progressive enhancement – renderValue()

или renderDate()

type RenderValue = (date: Date) => string | number | React.ReactElement;
const today = Date.now();
const App = () => {
  const [value, setValue] = React.useState();
  return (
    <DateInput
      defaultValue={today}
      renderValue={value === undefined ? (() => 'Сейчас') : undefined}
    />
  );
};

или

type RenderValue = (date: Date) => undefined | string | number | React.ReactElement;
const today = Date.now();
const App = () => {
   const [value, setValue] = React.useState();
   return (
    <DateInput
      defaultValue={today}
      renderValue={(date) => value === undefined && isToday(date) ? 'Сейчас' : undefined}
    />
  );
};

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍 решил сделать вторым способом, так как это более гибко. Добавил свойство renderCustomValue, с помощью которого можно настроить отображение

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

без defaultValue норм работает?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Я сделал так, что текст рендерится по условию в renderCustomValue. Так что defaultValue как будто и не нужен

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
2 participants