@driveflux/pdf 4.0.79 → 4.0.80
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.
- package/dist/components/FluxLogo.js +62 -3
- package/dist/components/StandardPage.js +108 -10
- package/dist/index.js +0 -1
- package/dist/templates/QuotationPdf/CustomerSubscriptionSection.js +145 -27
- package/dist/templates/QuotationPdf/GFV.js +49 -12
- package/dist/templates/QuotationPdf/Header.js +63 -5
- package/dist/templates/QuotationPdf/Pricing.js +573 -191
- package/dist/templates/QuotationPdf/QuotationPdfPage.js +23 -3
- package/dist/templates/QuotationPdf/SectionBoxNew.js +34 -4
- package/dist/templates/QuotationPdf/TermsSection.js +42 -5
- package/dist/templates/QuotationPdf/VehiclePhotos.js +54 -24
- package/dist/templates/QuotationPdf/index.js +197 -10
- package/dist/templates/QuotationPdf/translations.js +34 -22
- package/dist/templates/QuotationPdf/utils.js +92 -49
- package/dist/templates/SubscriptionAgreement/Confirmation.js +65 -10
- package/dist/templates/SubscriptionAgreement/CoverPage.js +93 -10
- package/dist/templates/SubscriptionAgreement/CoverPageSection.js +16 -5
- package/dist/templates/SubscriptionAgreement/Details.js +139 -59
- package/dist/templates/SubscriptionAgreement/Footer.js +48 -6
- package/dist/templates/SubscriptionAgreement/Header.js +35 -5
- package/dist/templates/SubscriptionAgreement/LabelValue.js +25 -3
- package/dist/templates/SubscriptionAgreement/SubscriptionAgreementPage.js +26 -3
- package/dist/templates/SubscriptionAgreement/TermsOfUse.js +94 -8
- package/dist/templates/SubscriptionAgreement/TermsOfUseSubSection.js +97 -11
- package/dist/templates/SubscriptionAgreement/index.js +253 -15
- package/dist/templates/SubscriptionAgreement/translations.js +195 -194
- package/dist/templates/SubscriptionAgreement/types.js +1 -2
- package/dist/templates/SubscriptionAgreement/utils.js +16 -11
- package/dist/templates/index.js +0 -1
- package/dist/theme/colors.js +44 -63
- package/dist/theme/index.js +0 -1
- package/dist/types.js +1 -2
- package/dist/utils.js +167 -16
- package/dist/watch.js +3 -4
- package/package.json +2 -2
|
@@ -3,8 +3,28 @@ import { View } from '@react-pdf/renderer';
|
|
|
3
3
|
import { format } from 'date-fns';
|
|
4
4
|
import StandardPage from '../../components/StandardPage.js';
|
|
5
5
|
import Header from './Header.js';
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
var QuotationPdfPage = function QuotationPdfPage(param) {
|
|
7
|
+
var quotation = param.quotation, children = param.children;
|
|
8
|
+
return /*#__PURE__*/ _jsxs(StandardPage, {
|
|
9
|
+
style: {
|
|
10
|
+
padding: 40,
|
|
11
|
+
fontSize: 10,
|
|
12
|
+
gap: 16
|
|
13
|
+
},
|
|
14
|
+
children: [
|
|
15
|
+
/*#__PURE__*/ _jsx(Header, {
|
|
16
|
+
tTitle: 'Quotation',
|
|
17
|
+
quotationId: quotation.id,
|
|
18
|
+
quotationDate: format(quotation.createdAt, 'dd-MM-yyyy')
|
|
19
|
+
}),
|
|
20
|
+
/*#__PURE__*/ _jsx(View, {
|
|
21
|
+
style: {
|
|
22
|
+
flex: 1,
|
|
23
|
+
rowGap: 24
|
|
24
|
+
},
|
|
25
|
+
children: children
|
|
26
|
+
})
|
|
27
|
+
]
|
|
28
|
+
});
|
|
8
29
|
};
|
|
9
30
|
export default QuotationPdfPage;
|
|
10
|
-
//# sourceMappingURL=QuotationPdfPage.js.map
|
|
@@ -1,8 +1,38 @@
|
|
|
1
|
-
import { jsx as _jsx,
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
2
|
import { View } from '@react-pdf/renderer';
|
|
3
3
|
import { colors } from '../../theme/colors.js';
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
var SectionBoxNew = function SectionBoxNew(param) {
|
|
5
|
+
var topContent = param.topContent, bottomContent = param.bottomContent, children = param.children;
|
|
6
|
+
return /*#__PURE__*/ _jsxs(View, {
|
|
7
|
+
style: {
|
|
8
|
+
border: "1px solid ".concat(colors.primary2)
|
|
9
|
+
},
|
|
10
|
+
children: [
|
|
11
|
+
/*#__PURE__*/ _jsx(View, {
|
|
12
|
+
style: {
|
|
13
|
+
padding: 16,
|
|
14
|
+
rowGap: 16
|
|
15
|
+
},
|
|
16
|
+
children: topContent
|
|
17
|
+
}),
|
|
18
|
+
bottomContent && /*#__PURE__*/ _jsxs(_Fragment, {
|
|
19
|
+
children: [
|
|
20
|
+
/*#__PURE__*/ _jsx(View, {
|
|
21
|
+
style: {
|
|
22
|
+
borderBottom: "1px solid ".concat(colors.primary2)
|
|
23
|
+
}
|
|
24
|
+
}),
|
|
25
|
+
/*#__PURE__*/ _jsx(View, {
|
|
26
|
+
style: {
|
|
27
|
+
padding: 16,
|
|
28
|
+
rowGap: 16
|
|
29
|
+
},
|
|
30
|
+
children: bottomContent
|
|
31
|
+
})
|
|
32
|
+
]
|
|
33
|
+
}),
|
|
34
|
+
children
|
|
35
|
+
]
|
|
36
|
+
});
|
|
6
37
|
};
|
|
7
38
|
export default SectionBoxNew;
|
|
8
|
-
//# sourceMappingURL=SectionBoxNew.js.map
|
|
@@ -1,13 +1,50 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { Text, View } from '@react-pdf/renderer';
|
|
3
3
|
import { colors } from '../../theme/colors.js';
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
var TermsSection = function TermsSection(param) {
|
|
5
|
+
var t = param.t;
|
|
6
|
+
return /*#__PURE__*/ _jsxs(View, {
|
|
7
|
+
style: {
|
|
8
|
+
gap: 16
|
|
9
|
+
},
|
|
10
|
+
children: [
|
|
11
|
+
/*#__PURE__*/ _jsx(Text, {
|
|
12
|
+
style: {
|
|
6
13
|
fontWeight: 'bold',
|
|
7
14
|
color: colors.black,
|
|
8
15
|
letterSpacing: 1,
|
|
9
|
-
textTransform: 'uppercase'
|
|
10
|
-
},
|
|
16
|
+
textTransform: 'uppercase'
|
|
17
|
+
},
|
|
18
|
+
children: t === null || t === void 0 ? void 0 : t.title
|
|
19
|
+
}),
|
|
20
|
+
/*#__PURE__*/ _jsx(View, {
|
|
21
|
+
children: t.content.map(function(line, _i) {
|
|
22
|
+
return /*#__PURE__*/ _jsxs(View, {
|
|
23
|
+
style: {
|
|
24
|
+
flexDirection: 'row',
|
|
25
|
+
alignItems: 'flex-start'
|
|
26
|
+
},
|
|
27
|
+
children: [
|
|
28
|
+
/*#__PURE__*/ _jsx(Text, {
|
|
29
|
+
style: {
|
|
30
|
+
marginRight: 4,
|
|
31
|
+
fontSize: 8
|
|
32
|
+
},
|
|
33
|
+
children: "•"
|
|
34
|
+
}),
|
|
35
|
+
/*#__PURE__*/ _jsx(Text, {
|
|
36
|
+
style: {
|
|
37
|
+
color: colors.primary3,
|
|
38
|
+
letterSpacing: 1,
|
|
39
|
+
fontSize: 8
|
|
40
|
+
},
|
|
41
|
+
children: line
|
|
42
|
+
})
|
|
43
|
+
]
|
|
44
|
+
}, line);
|
|
45
|
+
})
|
|
46
|
+
})
|
|
47
|
+
]
|
|
48
|
+
});
|
|
11
49
|
};
|
|
12
50
|
export default TermsSection;
|
|
13
|
-
//# sourceMappingURL=TermsSection.js.map
|
|
@@ -2,35 +2,65 @@ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-run
|
|
|
2
2
|
import { Image, Text, View } from '@react-pdf/renderer';
|
|
3
3
|
import { colors } from '../../theme/colors.js';
|
|
4
4
|
import { getInspectionTypeTranslation } from './utils.js';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
var VehiclePhotos = function VehiclePhotos(param) {
|
|
6
|
+
var quotation = param.quotation, t = param.t;
|
|
7
|
+
var images = quotation.images;
|
|
8
|
+
return /*#__PURE__*/ _jsxs(View, {
|
|
9
|
+
style: {
|
|
10
|
+
border: "1px solid ".concat(colors.primary2),
|
|
11
|
+
padding: 16
|
|
12
|
+
},
|
|
13
|
+
children: [
|
|
14
|
+
/*#__PURE__*/ _jsx(Text, {
|
|
15
|
+
style: {
|
|
8
16
|
textTransform: 'uppercase',
|
|
9
17
|
fontSize: 12,
|
|
10
18
|
fontWeight: 'bold',
|
|
11
|
-
marginBottom: 16
|
|
12
|
-
},
|
|
19
|
+
marginBottom: 16
|
|
20
|
+
},
|
|
21
|
+
children: t === null || t === void 0 ? void 0 : t.title
|
|
22
|
+
}),
|
|
23
|
+
/*#__PURE__*/ _jsx(View, {
|
|
24
|
+
style: {
|
|
13
25
|
display: 'flex',
|
|
14
26
|
flexDirection: 'row',
|
|
15
27
|
flexWrap: 'wrap',
|
|
16
|
-
gap: 15
|
|
17
|
-
},
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
,
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
28
|
+
gap: 15
|
|
29
|
+
},
|
|
30
|
+
children: images.map(function(image) {
|
|
31
|
+
return /*#__PURE__*/ _jsx(_Fragment, {
|
|
32
|
+
children: /*#__PURE__*/ _jsxs(View, {
|
|
33
|
+
style: {
|
|
34
|
+
overflow: 'hidden',
|
|
35
|
+
alignItems: 'center',
|
|
36
|
+
gap: 4
|
|
37
|
+
},
|
|
38
|
+
children: [
|
|
39
|
+
/*#__PURE__*/ _jsx(View, {
|
|
40
|
+
children: /*#__PURE__*/ _jsx(Image, {
|
|
41
|
+
// @ts-expect-error
|
|
42
|
+
source: image.default,
|
|
43
|
+
style: {
|
|
44
|
+
objectFit: 'cover',
|
|
45
|
+
height: 90,
|
|
46
|
+
width: 150
|
|
47
|
+
}
|
|
48
|
+
})
|
|
49
|
+
}),
|
|
50
|
+
image.inspectionType && /*#__PURE__*/ _jsx(Text, {
|
|
51
|
+
style: {
|
|
52
|
+
color: colors.black,
|
|
53
|
+
fontSize: 10,
|
|
54
|
+
textAlign: 'center'
|
|
55
|
+
},
|
|
56
|
+
children: getInspectionTypeTranslation(image.inspectionType)
|
|
57
|
+
})
|
|
58
|
+
]
|
|
59
|
+
}, image.default)
|
|
60
|
+
});
|
|
61
|
+
})
|
|
62
|
+
})
|
|
63
|
+
]
|
|
64
|
+
});
|
|
34
65
|
};
|
|
35
66
|
export default VehiclePhotos;
|
|
36
|
-
//# sourceMappingURL=VehiclePhotos.js.map
|
|
@@ -1,3 +1,131 @@
|
|
|
1
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
2
|
+
try {
|
|
3
|
+
var info = gen[key](arg);
|
|
4
|
+
var value = info.value;
|
|
5
|
+
} catch (error) {
|
|
6
|
+
reject(error);
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
if (info.done) {
|
|
10
|
+
resolve(value);
|
|
11
|
+
} else {
|
|
12
|
+
Promise.resolve(value).then(_next, _throw);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function _async_to_generator(fn) {
|
|
16
|
+
return function() {
|
|
17
|
+
var self = this, args = arguments;
|
|
18
|
+
return new Promise(function(resolve, reject) {
|
|
19
|
+
var gen = fn.apply(self, args);
|
|
20
|
+
function _next(value) {
|
|
21
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
22
|
+
}
|
|
23
|
+
function _throw(err) {
|
|
24
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
25
|
+
}
|
|
26
|
+
_next(undefined);
|
|
27
|
+
});
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function _ts_generator(thisArg, body) {
|
|
31
|
+
var f, y, t, _ = {
|
|
32
|
+
label: 0,
|
|
33
|
+
sent: function() {
|
|
34
|
+
if (t[0] & 1) throw t[1];
|
|
35
|
+
return t[1];
|
|
36
|
+
},
|
|
37
|
+
trys: [],
|
|
38
|
+
ops: []
|
|
39
|
+
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype), d = Object.defineProperty;
|
|
40
|
+
return d(g, "next", {
|
|
41
|
+
value: verb(0)
|
|
42
|
+
}), d(g, "throw", {
|
|
43
|
+
value: verb(1)
|
|
44
|
+
}), d(g, "return", {
|
|
45
|
+
value: verb(2)
|
|
46
|
+
}), typeof Symbol === "function" && d(g, Symbol.iterator, {
|
|
47
|
+
value: function() {
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
}), g;
|
|
51
|
+
function verb(n) {
|
|
52
|
+
return function(v) {
|
|
53
|
+
return step([
|
|
54
|
+
n,
|
|
55
|
+
v
|
|
56
|
+
]);
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
function step(op) {
|
|
60
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
61
|
+
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
62
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
63
|
+
if (y = 0, t) op = [
|
|
64
|
+
op[0] & 2,
|
|
65
|
+
t.value
|
|
66
|
+
];
|
|
67
|
+
switch(op[0]){
|
|
68
|
+
case 0:
|
|
69
|
+
case 1:
|
|
70
|
+
t = op;
|
|
71
|
+
break;
|
|
72
|
+
case 4:
|
|
73
|
+
_.label++;
|
|
74
|
+
return {
|
|
75
|
+
value: op[1],
|
|
76
|
+
done: false
|
|
77
|
+
};
|
|
78
|
+
case 5:
|
|
79
|
+
_.label++;
|
|
80
|
+
y = op[1];
|
|
81
|
+
op = [
|
|
82
|
+
0
|
|
83
|
+
];
|
|
84
|
+
continue;
|
|
85
|
+
case 7:
|
|
86
|
+
op = _.ops.pop();
|
|
87
|
+
_.trys.pop();
|
|
88
|
+
continue;
|
|
89
|
+
default:
|
|
90
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
91
|
+
_ = 0;
|
|
92
|
+
continue;
|
|
93
|
+
}
|
|
94
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
95
|
+
_.label = op[1];
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
99
|
+
_.label = t[1];
|
|
100
|
+
t = op;
|
|
101
|
+
break;
|
|
102
|
+
}
|
|
103
|
+
if (t && _.label < t[2]) {
|
|
104
|
+
_.label = t[2];
|
|
105
|
+
_.ops.push(op);
|
|
106
|
+
break;
|
|
107
|
+
}
|
|
108
|
+
if (t[2]) _.ops.pop();
|
|
109
|
+
_.trys.pop();
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
op = body.call(thisArg, _);
|
|
113
|
+
} catch (e) {
|
|
114
|
+
op = [
|
|
115
|
+
6,
|
|
116
|
+
e
|
|
117
|
+
];
|
|
118
|
+
y = 0;
|
|
119
|
+
} finally{
|
|
120
|
+
f = t = 0;
|
|
121
|
+
}
|
|
122
|
+
if (op[0] & 5) throw op[1];
|
|
123
|
+
return {
|
|
124
|
+
value: op[0] ? op[1] : void 0,
|
|
125
|
+
done: true
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
}
|
|
1
129
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
130
|
import { Document } from '@react-pdf/renderer';
|
|
3
131
|
import { useMemo } from 'react';
|
|
@@ -10,18 +138,77 @@ import QuotationPdfPage from './QuotationPdfPage.js';
|
|
|
10
138
|
import TermsSection from './TermsSection.js';
|
|
11
139
|
import { useTranslations } from './translations.js';
|
|
12
140
|
import VehiclePhotos from './VehiclePhotos.js';
|
|
13
|
-
export
|
|
14
|
-
|
|
141
|
+
export var generateQuotationPdf = function generateQuotationPdf(param, fileName) {
|
|
142
|
+
var _param_locale = param.locale, locale = _param_locale === void 0 ? 'en' : _param_locale, quotation = param.quotation;
|
|
143
|
+
return _async_to_generator(function() {
|
|
144
|
+
return _ts_generator(this, function(_state) {
|
|
145
|
+
switch(_state.label){
|
|
146
|
+
case 0:
|
|
147
|
+
return [
|
|
148
|
+
4,
|
|
149
|
+
toPdf(/*#__PURE__*/ _jsx(QuotationPDF, {
|
|
150
|
+
locale: locale,
|
|
151
|
+
quotation: quotation
|
|
152
|
+
}), fileName)
|
|
153
|
+
];
|
|
154
|
+
case 1:
|
|
155
|
+
return [
|
|
156
|
+
2,
|
|
157
|
+
_state.sent()
|
|
158
|
+
];
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
})();
|
|
15
162
|
};
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
163
|
+
var QuotationPDF = function QuotationPDF(param) {
|
|
164
|
+
var _param_locale = param.locale, locale = _param_locale === void 0 ? 'en' : _param_locale, quotation = param.quotation;
|
|
165
|
+
var th = useTranslations(locale);
|
|
166
|
+
var pageProps = useMemo(function() {
|
|
19
167
|
return {
|
|
20
168
|
t: th,
|
|
21
|
-
quotation: quotation
|
|
169
|
+
quotation: quotation
|
|
22
170
|
};
|
|
23
|
-
}, [
|
|
24
|
-
|
|
25
|
-
|
|
171
|
+
}, [
|
|
172
|
+
th,
|
|
173
|
+
quotation
|
|
174
|
+
]);
|
|
175
|
+
var t = pageProps.t;
|
|
176
|
+
return /*#__PURE__*/ _jsxs(Document, {
|
|
177
|
+
language: locale,
|
|
178
|
+
children: [
|
|
179
|
+
/*#__PURE__*/ _jsxs(QuotationPdfPage, {
|
|
180
|
+
quotation: quotation,
|
|
181
|
+
children: [
|
|
182
|
+
/*#__PURE__*/ _jsx(CustomerSubscriptionSection, {
|
|
183
|
+
quotation: quotation,
|
|
184
|
+
t: t
|
|
185
|
+
}),
|
|
186
|
+
/*#__PURE__*/ _jsx(Pricing, {
|
|
187
|
+
quotation: quotation,
|
|
188
|
+
t: t.pricing
|
|
189
|
+
}),
|
|
190
|
+
quotation.fees.gfv && /*#__PURE__*/ _jsx(GFV, {
|
|
191
|
+
quotation: quotation,
|
|
192
|
+
t: t.pricing
|
|
193
|
+
})
|
|
194
|
+
]
|
|
195
|
+
}),
|
|
196
|
+
/*#__PURE__*/ _jsxs(StandardPage, {
|
|
197
|
+
style: {
|
|
198
|
+
padding: 40,
|
|
199
|
+
fontSize: 10,
|
|
200
|
+
gap: 16
|
|
201
|
+
},
|
|
202
|
+
children: [
|
|
203
|
+
/*#__PURE__*/ _jsx(VehiclePhotos, {
|
|
204
|
+
quotation: quotation,
|
|
205
|
+
t: t.vehiclePhotos
|
|
206
|
+
}),
|
|
207
|
+
/*#__PURE__*/ _jsx(TermsSection, {
|
|
208
|
+
t: t.terms
|
|
209
|
+
})
|
|
210
|
+
]
|
|
211
|
+
})
|
|
212
|
+
]
|
|
213
|
+
});
|
|
26
214
|
};
|
|
27
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
var enTranslation = {
|
|
2
2
|
quotation: 'Quotation',
|
|
3
3
|
date: 'Date',
|
|
4
4
|
customer: {
|
|
5
5
|
title: 'Customer',
|
|
6
6
|
name: 'Name',
|
|
7
7
|
email: 'Email',
|
|
8
|
-
address: 'Address'
|
|
8
|
+
address: 'Address'
|
|
9
9
|
},
|
|
10
10
|
subscription: {
|
|
11
11
|
title: 'Subscription',
|
|
12
12
|
vehicleName: 'Vehicle',
|
|
13
13
|
plan: 'Subscription Plan',
|
|
14
|
-
mileagePackage: 'Mileage Package'
|
|
14
|
+
mileagePackage: 'Mileage Package'
|
|
15
15
|
},
|
|
16
16
|
subIncludes: {
|
|
17
17
|
title: "What's Included:",
|
|
@@ -25,12 +25,14 @@ const enTranslation = {
|
|
|
25
25
|
'24/7 nationwide roadside assistance',
|
|
26
26
|
'Theft recovery services',
|
|
27
27
|
'Independently rated vehicle inspection',
|
|
28
|
-
'Option to purchase the vehicle at the end of the subscription'
|
|
28
|
+
'Option to purchase the vehicle at the end of the subscription'
|
|
29
29
|
],
|
|
30
30
|
excessMileage: {
|
|
31
31
|
title: 'Excess Mileage Fees',
|
|
32
|
-
description: (excessMileage)
|
|
33
|
-
|
|
32
|
+
description: function description(excessMileage) {
|
|
33
|
+
return "If usage exceeds chosen mileage package, excess mileage fees for this vehicle is RM".concat(excessMileage, " per KM.");
|
|
34
|
+
}
|
|
35
|
+
}
|
|
34
36
|
},
|
|
35
37
|
pricing: {
|
|
36
38
|
title: 'Pricing',
|
|
@@ -39,28 +41,39 @@ const enTranslation = {
|
|
|
39
41
|
upfront: {
|
|
40
42
|
title: 'Upfront Fees',
|
|
41
43
|
content: [
|
|
42
|
-
{
|
|
43
|
-
|
|
44
|
+
{
|
|
45
|
+
title: 'Booking Fee',
|
|
46
|
+
key: 'reservationFee'
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
title: 'Refundable Deposit*',
|
|
50
|
+
key: 'deposit'
|
|
51
|
+
}
|
|
44
52
|
],
|
|
45
|
-
depositDisclaimer: '* The deposit will be refunded to you once the finalization upon your FLUX car is done excluding any service fee, tax, damages, fines, penalties or excess mileage charges that have incurred'
|
|
53
|
+
depositDisclaimer: '* The deposit will be refunded to you once the finalization upon your FLUX car is done excluding any service fee, tax, damages, fines, penalties or excess mileage charges that have incurred'
|
|
46
54
|
},
|
|
47
55
|
monthly: {
|
|
48
56
|
title: 'Monthly Fees',
|
|
49
|
-
content: [
|
|
57
|
+
content: [
|
|
58
|
+
{
|
|
59
|
+
title: 'Subscription Fee',
|
|
60
|
+
key: 'subscriptionFee'
|
|
61
|
+
}
|
|
62
|
+
]
|
|
50
63
|
},
|
|
51
64
|
dueToday: {
|
|
52
65
|
title: 'Due Today',
|
|
53
66
|
description: 'Grand Total is due before your subscription start. Monthly fee is due on the first day of every cycle period.',
|
|
54
67
|
subTotal: 'Upfront Fees + Monthly Fee',
|
|
55
|
-
grandTotal: 'Grand Total'
|
|
68
|
+
grandTotal: 'Grand Total'
|
|
56
69
|
},
|
|
57
70
|
extraCharge: 'Extra Charge',
|
|
58
71
|
promo: 'Promo',
|
|
59
72
|
gfv: {
|
|
60
|
-
title: 'Guaranteed Future Value (GFV)'
|
|
73
|
+
title: 'Guaranteed Future Value (GFV)'
|
|
61
74
|
},
|
|
62
|
-
totalDiscount: 'Total Discount'
|
|
63
|
-
}
|
|
75
|
+
totalDiscount: 'Total Discount'
|
|
76
|
+
}
|
|
64
77
|
},
|
|
65
78
|
terms: {
|
|
66
79
|
title: 'Terms',
|
|
@@ -73,17 +86,16 @@ const enTranslation = {
|
|
|
73
86
|
'The upfront fees are billed one-time per subscription, before the subscription starts.',
|
|
74
87
|
'All monthly recurring fees are billed on the same date as the delivery of the vehicle.',
|
|
75
88
|
'Scheduling delivery will only commence Grand Total is fully paid, 7 - 30+ days after payment and subject to vehicle availability.',
|
|
76
|
-
'Guaranteed Future Value prices are not inclusive of processing fees'
|
|
77
|
-
]
|
|
89
|
+
'Guaranteed Future Value prices are not inclusive of processing fees'
|
|
90
|
+
]
|
|
78
91
|
},
|
|
79
92
|
vehiclePhotos: {
|
|
80
|
-
title: 'Vehicle Photos'
|
|
81
|
-
}
|
|
93
|
+
title: 'Vehicle Photos'
|
|
94
|
+
}
|
|
82
95
|
};
|
|
83
|
-
export
|
|
84
|
-
|
|
85
|
-
en: enTranslation
|
|
96
|
+
export var useTranslations = function useTranslations(locale) {
|
|
97
|
+
var translation = {
|
|
98
|
+
en: enTranslation
|
|
86
99
|
};
|
|
87
100
|
return translation[locale];
|
|
88
101
|
};
|
|
89
|
-
//# sourceMappingURL=translations.js.map
|