Repository URL to install this package:
|
Version:
3.2.0 ▾
|
<!doctype html>
<html lang="en">
<head>
<title>Code coverage report for validators/isValidDates.ts</title>
<meta charset="utf-8" />
<link rel="stylesheet" href="../prettify.css" />
<link rel="stylesheet" href="../base.css" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<style type='text/css'>
.coverage-summary .sorter {
background-image: url(../sort-arrow-sprite.png);
}
</style>
</head>
<body>
<div class='wrapper'>
<div class='pad1'>
<h1>
<a href="../index.html">All files</a> / <a href="index.html">validators</a> isValidDates.ts
</h1>
<div class='clearfix'>
<div class='fl pad1y space-right2'>
<span class="strong">59.26% </span>
<span class="quiet">Statements</span>
<span class='fraction'>16/27</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">11.76% </span>
<span class="quiet">Branches</span>
<span class='fraction'>2/17</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">33.33% </span>
<span class="quiet">Functions</span>
<span class='fraction'>2/6</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">59.26% </span>
<span class="quiet">Lines</span>
<span class='fraction'>16/27</span>
</div>
</div>
</div>
<div class='status-line medium'></div>
<pre><table class="coverage">
<tr><td class="line-count quiet">1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">2x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">2x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-yes">10x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import { observable } from 'xmobx/mobx'
import { toNumber } from 'exotic'
import {
isValidDate,
currentYear,
currentMonth,
currentYearTwoDigit,
} from './isValidExpiryDate'
type MonthYearType = string | number | any
// time match hours, minutes, and seconds, 24-hour clock
// const matchTimeString = /^(2[0-3]|[01]?[0-9]):([0-5]?[0-9]):([0-5]?[0-9])$/
// // dateString match m/d/yy and mm/dd/yyyy, allowing any combination of one or two digits for the day and month, and two or four digits for the year
// const matchFullDate = /^(1[0-2]|0?[1-9])([\/-])(3[01]|[12][0-9]|0?[1-9])(?:\2)(?:[0-9]{2})?[0-9]{2}$/
// const matchMonth = /^[0-9]*$/gm
const matchMonthSpecicalChar = /^\d{0,2}(?:\.\d)?$/
// function isValidMonth(value: string | Date): boolean {
// // .value == new Date().getFullYear()
// const isBeforeOneMonthAhead = value < new Date().getMonth() + 1
// // The credit card has expired. Choose a different expiration date.
// if (isBeforeOneMonthAhead) {
// return false
// }
// return true
// }
/**
* @see https://date-fns.org/
*
* @todo - use date_fns
* @todo - use in the dateParse util
* @todo - use in t<span class="fstat-no" title="function not covered" >im</span>e atom
*/
// const monthValidateToZero = item => {
// <span class="cstat-no" title="statement not covered" > const zero = 0</span>
// const value = item.length >= 2 ? item : zero + item
// return value<span class="fstat-no" title="function not covered" ></span>
// }<span class="cstat-no" title="statement not covered" ></span>
const ma<span class="cstat-no" title="statement not covered" >tchLimit = (month: number) => {</span>
// const removeSpecialCharacters = month.replace(matchMonthSpecicalChar, '')
// const validateToZero = monthValidateToZero(month)
return<span class="cstat-no" title="statement not covered" > month > 0 && month <= 12</span>
}
export const monthValidationForYear = (
month: number,
year: number
): boolean => {
if (
year === toNumber(currentYear) ||
year === toNumber(currentYearTwoDigit)
) {
return currentMonth <= month
} else {<span class="missing-if-branch" title="if path not taken" >I</span>
return match<span class="branch-1 cbranch-no" title="branch not covered" >Limit(month)</span>
}<span class="branch-2 cbranch-no" title="branch not covered" ></span>
}<span class="cstat-no" title="statement not covered" ></span>
// function isValidDate() {
// //
// }
// @observer
// extends React.Component
class ExpiryDateValidation <span class="fstat-no" title="function not covered" >{</span>
isValidMonth = (year: MonthYearType<span class="cstat-no" title="statement not covered" >, month: MonthYearType)</span>: boolean => {
if (<span class="cstat-no" title="statement not covered" ></span>
month <span class="cstat-no" title="statement not covered" >&&</span>
monthValidationForYear(month, year) &&
matchMonthSpecicalChar.te<span class="cstat-no" title="statement not covered" >st(month)</span>
) {
return tru<span class="cstat-no" title="statement not covered" >e</span>
} else {
return<span class="cstat-no" title="statement not covered" > false</span>
}
}
is<span class="fstat-no" title="function not covered" >Va</span>lidYear = (year: MonthYearType, month: MonthYearType): boolean => {
const expiryYearLength = year.toString().length
const validYear = false
if (
(expiryYearLength === 4 && year >= toNumber(currentYear)) ||
(expiryYearLength === 2 && year >= toNumber(currentYearTwoDigit))
) {
const result = isValidMonth(year, month)
// result ? this.isValidMonth(year, month) : false
return result
}
return validYear
}
isValidTimeOrDay() {
//
}
}
const expiryDate = new ExpiryDateValidation()
const isValidMonth = expiryDate.isValidMonth
const isValidYear = expiryDate.isValidYear
export { isValidMonth, isValidYear, expiryDate }
</pre></td></tr>
</table></pre>
<div class='push'></div><!-- for sticky footer -->
</div><!-- /wrapper -->
<div class='footer quiet pad2 space-top1 center small'>
Code coverage
generated by <a href="https://istanbul.js.org/" target="_blank">istanbul</a> at Sat Nov 10 2018 05:28:54 GMT-0800 (Pacific Standard Time)
</div>
</div>
<script src="../prettify.js"></script>
<script>
window.onload = function () {
if (typeof prettyPrint === 'function') {
prettyPrint();
}
};
</script>
<script src="../sorter.js"></script>
</body>
</html>