@bsol-oss/react-datatable5 13.0.1-beta.7 → 13.0.1-beta.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,11 +1,10 @@
1
- import { DatePickerLabels } from './DatePicker';
2
- import { TimePickerLabels } from '../Form/components/types/CustomJSONSchema7';
1
+ import { DateTimePickerLabels, TimePickerLabels } from '../Form/components/types/CustomJSONSchema7';
3
2
  interface DateTimePickerProps {
4
3
  value?: string;
5
4
  onChange?: (date?: string) => void;
6
5
  format?: 'date-time' | 'iso-date-time';
7
6
  showSeconds?: boolean;
8
- labels?: DatePickerLabels;
7
+ labels?: DateTimePickerLabels;
9
8
  timePickerLabels?: TimePickerLabels;
10
9
  timezone?: string;
11
10
  startTime?: string;
@@ -13,18 +12,20 @@ interface DateTimePickerProps {
13
12
  maxDate?: Date;
14
13
  portalled?: boolean;
15
14
  defaultDate?: string;
16
- defaultTime?: TimeData;
15
+ defaultTime?: {
16
+ hour: number | null;
17
+ minute: number | null;
18
+ second?: number | null;
19
+ meridiem?: 'am' | 'pm' | null;
20
+ };
21
+ showQuickActions?: boolean;
22
+ quickActionLabels?: {
23
+ yesterday?: string;
24
+ today?: string;
25
+ tomorrow?: string;
26
+ plus7Days?: string;
27
+ };
28
+ showTimezoneSelector?: boolean;
17
29
  }
18
- interface TimeData12Hour {
19
- hour: number | null;
20
- minute: number | null;
21
- meridiem: 'am' | 'pm' | null;
22
- }
23
- interface TimeData24Hour {
24
- hour: number | null;
25
- minute: number | null;
26
- second?: number | null;
27
- }
28
- type TimeData = TimeData12Hour | TimeData24Hour;
29
- export declare function DateTimePicker({ value, onChange, format, showSeconds, labels, timePickerLabels, timezone, startTime, minDate, maxDate, portalled, defaultDate, defaultTime, }: DateTimePickerProps): import("react/jsx-runtime").JSX.Element;
30
+ export declare function DateTimePicker({ value, onChange, format, showSeconds, labels, timePickerLabels, timezone: tz, startTime, minDate, maxDate, portalled, defaultDate, defaultTime, showQuickActions, quickActionLabels, showTimezoneSelector, }: DateTimePickerProps): import("react/jsx-runtime").JSX.Element;
30
31
  export {};
@@ -1,9 +1,8 @@
1
- type FormatType = "date" | "time" | "date-time" | "iso-time" | "iso-date-time" | "duration";
1
+ type FormatType = 'date' | 'time' | 'date-time' | 'iso-time' | 'iso-date-time' | 'duration';
2
2
  interface UniversalPickerProps {
3
3
  format: FormatType;
4
4
  value?: string | null;
5
5
  onChange?: (value: string | null) => void;
6
- placeholder?: string;
7
6
  }
8
- export declare function UniversalPicker({ format, value, onChange, placeholder, }: UniversalPickerProps): import("react/jsx-runtime").JSX.Element;
7
+ export declare function UniversalPicker({ format, value, onChange, }: UniversalPickerProps): import("react/jsx-runtime").JSX.Element;
9
8
  export {};
@@ -1,6 +1,5 @@
1
1
  export { default as DatePicker } from './DatePicker';
2
2
  export { TimePicker } from '../TimePicker/TimePicker';
3
- export { IsoTimePicker } from './IsoTimePicker';
4
3
  export { DateTimePicker } from './DateTimePicker';
5
4
  export { DurationPicker } from './DurationPicker';
6
5
  export { UniversalPicker } from './UniversalPicker';
@@ -26,6 +26,7 @@ export interface UseIdPickerDataReturn {
26
26
  missingIds: string[];
27
27
  comboboxItems: Array<{
28
28
  label: string;
29
+ displayLabel: string;
29
30
  value: string;
30
31
  raw: RecordType;
31
32
  }>;
@@ -33,6 +34,7 @@ export interface UseIdPickerDataReturn {
33
34
  filter: (text: string) => void;
34
35
  set: (items: Array<{
35
36
  label: string;
37
+ displayLabel: string;
36
38
  value: string;
37
39
  raw: RecordType;
38
40
  }>) => void;
@@ -40,6 +42,8 @@ export interface UseIdPickerDataReturn {
40
42
  idPickerLabels: any;
41
43
  insideDialog: boolean;
42
44
  renderDisplay: ((item: RecordType) => React.ReactNode) | undefined;
45
+ itemToValue: (item: RecordType) => string;
46
+ itemToString: (item: RecordType) => string;
43
47
  loadInitialValues: (params: LoadInitialValuesParams) => Promise<LoadInitialValuesResult>;
44
48
  column_ref: string;
45
49
  errors: any;
@@ -79,6 +79,7 @@ export interface CustomJSONSchema7 extends JSONSchema7 {
79
79
  foreign_key?: ForeignKeyProps;
80
80
  variant?: string;
81
81
  renderDisplay?: (item: unknown) => ReactNode;
82
+ itemToValue?: (item: unknown) => string;
82
83
  loadInitialValues?: (params: LoadInitialValuesParams) => Promise<LoadInitialValuesResult>;
83
84
  inputRender?: (props: {
84
85
  column: string;
@@ -1,13 +1,18 @@
1
1
  import { Dispatch, SetStateAction } from 'react';
2
2
  import { TimePickerLabels } from '../Form/components/types/CustomJSONSchema7';
3
- interface TimePickerProps {
4
- hour: number | null;
5
- setHour: Dispatch<SetStateAction<number | null>>;
6
- minute: number | null;
7
- setMinute: Dispatch<SetStateAction<number | null>>;
8
- meridiem: 'am' | 'pm' | null;
9
- setMeridiem: Dispatch<SetStateAction<'am' | 'pm' | null>>;
10
- onChange?: (newValue: {
3
+ type TimePickerProps12h = {
4
+ format?: '12h';
5
+ value?: string;
6
+ onChange?: (value: string | undefined) => void;
7
+ hour?: number | null;
8
+ setHour?: Dispatch<SetStateAction<number | null>>;
9
+ minute?: number | null;
10
+ setMinute?: Dispatch<SetStateAction<number | null>>;
11
+ meridiem?: 'am' | 'pm' | null;
12
+ setMeridiem?: Dispatch<SetStateAction<'am' | 'pm' | null>>;
13
+ second?: never;
14
+ setSecond?: never;
15
+ onTimeChange?: (newValue: {
11
16
  hour: number | null;
12
17
  minute: number | null;
13
18
  meridiem: 'am' | 'pm' | null;
@@ -17,6 +22,30 @@ interface TimePickerProps {
17
22
  timezone?: string;
18
23
  portalled?: boolean;
19
24
  labels?: TimePickerLabels;
20
- }
21
- export declare const TimePicker: ({ hour, setHour, minute, setMinute, meridiem, setMeridiem, onChange, startTime, selectedDate, timezone, portalled, labels, }: TimePickerProps) => import("react/jsx-runtime").JSX.Element;
25
+ };
26
+ type TimePickerProps24h = {
27
+ format: '24h';
28
+ value?: string;
29
+ onChange?: (value: string | undefined) => void;
30
+ hour?: number | null;
31
+ setHour?: Dispatch<SetStateAction<number | null>>;
32
+ minute?: number | null;
33
+ setMinute?: Dispatch<SetStateAction<number | null>>;
34
+ second?: number | null;
35
+ setSecond?: Dispatch<SetStateAction<number | null>>;
36
+ meridiem?: never;
37
+ setMeridiem?: never;
38
+ onTimeChange?: (newValue: {
39
+ hour: number | null;
40
+ minute: number | null;
41
+ second: number | null;
42
+ }) => void;
43
+ startTime?: string;
44
+ selectedDate?: string;
45
+ timezone?: string;
46
+ portalled?: boolean;
47
+ labels?: TimePickerLabels;
48
+ };
49
+ export type TimePickerProps = TimePickerProps12h | TimePickerProps24h;
50
+ export declare const TimePicker: (props: TimePickerProps) => import("react/jsx-runtime").JSX.Element;
22
51
  export {};
package/package.json CHANGED
@@ -1,11 +1,14 @@
1
1
  {
2
2
  "name": "@bsol-oss/react-datatable5",
3
- "version": "13.0.1-beta.7",
3
+ "version": "13.0.1-beta.9",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",
7
7
  "types": "dist/index.d.ts",
8
- "repository": "https://github.com/bsol-oss/react-datatable5.git",
8
+ "repository": {
9
+ "type": "git",
10
+ "url": "git+https://github.com/bsol-oss/react-datatable5.git"
11
+ },
9
12
  "homepage": "https://github.com/bsol-oss/react-datatable5#react-datatable5",
10
13
  "author": "screw123",
11
14
  "license": "MIT",
@@ -46,7 +49,7 @@
46
49
  "ajv": "^8.12.0",
47
50
  "ajv-errors": "^3.0.0",
48
51
  "ajv-formats": "^3.0.1",
49
- "axios": "^1.7.9",
52
+ "axios": "^1.13.2",
50
53
  "dayjs": "^1.11.13",
51
54
  "next-themes": "^0.4.4",
52
55
  "react": "^19.0.0",
@@ -80,7 +83,7 @@
80
83
  "lint-staged": "^16.2.5",
81
84
  "prettier": "3.2.5",
82
85
  "rollup-plugin-dts": "^6.1.0",
83
- "storybook": "^10.0.7",
86
+ "storybook": "^10.1.11",
84
87
  "typescript": "^5.2.2",
85
88
  "vite": "^5.2.0"
86
89
  },
@@ -1,24 +0,0 @@
1
- import { Dispatch, SetStateAction } from 'react';
2
- interface IsoTimePickerProps {
3
- hour: number | null;
4
- setHour: Dispatch<SetStateAction<number | null>>;
5
- minute: number | null;
6
- setMinute: Dispatch<SetStateAction<number | null>>;
7
- second: number | null;
8
- setSecond: Dispatch<SetStateAction<number | null>>;
9
- onChange?: (newValue: {
10
- hour: number | null;
11
- minute: number | null;
12
- second: number | null;
13
- }) => void;
14
- startTime?: string;
15
- selectedDate?: string;
16
- timezone?: string;
17
- portalled?: boolean;
18
- labels?: {
19
- placeholder?: string;
20
- emptyMessage?: string;
21
- };
22
- }
23
- export declare function IsoTimePicker({ hour, setHour, minute, setMinute, second, setSecond, onChange, startTime, selectedDate, timezone, portalled, labels, }: IsoTimePickerProps): import("react/jsx-runtime").JSX.Element;
24
- export {};