playbook_ui 14.11.0.pre.rc.3 → 14.11.0.pre.rc.5

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: ecf72ed74e3b579c11f3ec65bcad5ef39066b5450a77792ab9cb2b6b604050ce
4
- data.tar.gz: '08d63e140dbbf4f6d1afa007e661ba5270d2f4092d8d3d4d1504a6a43628641c'
3
+ metadata.gz: 1eb04067fdadd5f71f0992668732e3676dee7a6cc09d262582b38062ed66fa7f
4
+ data.tar.gz: b358c411ab18b799ce72c37ac425633df7104c2843304dfd36ef1e33b47c2d30
5
5
  SHA512:
6
- metadata.gz: '0198bec37a39245fa764143ecf6c51128b02204ddf7ab6535f7d51094bfbc4ca1937da61b3ba2ef34d961e9c4c77bd8d8b6fd22d5d3cf1a028404952a2a99320'
7
- data.tar.gz: ca29f43dc9a9aa8f2b33d58e58fbffcabff6222ed49ef3803f78254380769fa59ad782d42ccfff2c44039b29c2a8c9e206696cf0c23450c7274bf27dc6c002b9
6
+ metadata.gz: b1e08d3dc1697229ff7a91fea552a43abcf7287736681b0c36f2bf4fea6f3edc1688e243b6a6a952aeb0511caca87ae27f88334ea011fbfa7a74d2e32ec61aef
7
+ data.tar.gz: 3d747f6188b22c7fa973150b10b379d7b3663e889889c4773fda6cb05c12df25b14c58965ca87855a91fcbd95e3d76734def93902a752620ad48792c80474c4f
@@ -19,8 +19,11 @@ $section_colors_dark: (
19
19
  align-items: center;
20
20
  position: relative;
21
21
  span {
22
- padding: 0 $space_xs;
22
+ padding: 0;
23
23
  display: flex;
24
+ [class*="pb_caption_kit"] {
25
+ padding: 0 $space_xs;
26
+ }
24
27
  }
25
28
  &::before {
26
29
  content: "";
@@ -123,6 +123,13 @@ const TextInput = (props: TextInputProps, ref: React.LegacyRef<HTMLInputElement>
123
123
 
124
124
  const childInput = children ? children.type === "input" : undefined
125
125
 
126
+ let formattedValue;
127
+ if (isMaskedInput && value) {
128
+ formattedValue = INPUTMASKS[mask].formatDefaultValue(value.toString())
129
+ } else {
130
+ formattedValue = value
131
+ }
132
+
126
133
  const textInput = (
127
134
  childInput ? React.cloneElement(children, { className: "text_input" }) :
128
135
  (<input
@@ -138,7 +145,7 @@ const TextInput = (props: TextInputProps, ref: React.LegacyRef<HTMLInputElement>
138
145
  ref={ref}
139
146
  required={required}
140
147
  type={type}
141
- value={value}
148
+ value={formattedValue}
142
149
  />)
143
150
  )
144
151
 
@@ -1,5 +1,6 @@
1
1
  type InputMask = {
2
2
  format: (value: string) => string
3
+ formatDefaultValue: (value: string) => string
3
4
  pattern: string
4
5
  placeholder: string
5
6
  }
@@ -8,6 +9,24 @@ type InputMaskDictionary = {
8
9
  [key in 'currency' | 'zipCode' | 'postalCode' | 'ssn']: InputMask
9
10
  }
10
11
 
12
+ const formatCurrencyDefaultValue = (value: string): string => {
13
+ // Remove non-numeric characters except for the decimal point
14
+ const numericValue = value.replace(/[^0-9.]/g, '')
15
+
16
+ if (!numericValue) return ''
17
+
18
+ // Parse the numeric value as a float to handle decimals
19
+ const dollars = parseFloat(numericValue)
20
+ if (isNaN(dollars) || dollars === 0) return ''
21
+
22
+ // Format as currency
23
+ return new Intl.NumberFormat('en-US', {
24
+ style: 'currency',
25
+ currency: 'USD',
26
+ maximumFractionDigits: 2,
27
+ }).format(dollars)
28
+ }
29
+
11
30
  const formatCurrency = (value: string): string => {
12
31
  const numericValue = value.replace(/[^0-9]/g, '').slice(0, 15)
13
32
 
@@ -42,22 +61,26 @@ const formatSSN = (value: string): string => {
42
61
  export const INPUTMASKS: InputMaskDictionary = {
43
62
  currency: {
44
63
  format: formatCurrency,
64
+ formatDefaultValue: formatCurrencyDefaultValue,
45
65
  // eslint-disable-next-line no-useless-escape
46
66
  pattern: '^\\$\\d{1,3}(?:,\\d{3})*(?:\\.\\d{2})?$',
47
67
  placeholder: '$0.00',
48
68
  },
49
69
  zipCode: {
50
70
  format: formatBasicPostal,
71
+ formatDefaultValue: formatBasicPostal,
51
72
  pattern: '\\d{5}',
52
73
  placeholder: '12345',
53
74
  },
54
75
  postalCode: {
55
76
  format: formatExtendedPostal,
77
+ formatDefaultValue: formatExtendedPostal,
56
78
  pattern: '\\d{5}-\\d{4}',
57
79
  placeholder: '12345-6789',
58
80
  },
59
81
  ssn: {
60
82
  format: formatSSN,
83
+ formatDefaultValue: formatSSN,
61
84
  pattern: '\\d{3}-\\d{2}-\\d{4}',
62
85
  placeholder: '123-45-6789',
63
86
  },