israeli-bank-scrapers 6.0.0 → 6.1.1

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.
Files changed (83) hide show
  1. package/README.md +1 -0
  2. package/lib/assertNever.js +5 -7
  3. package/lib/constants.js +13 -16
  4. package/lib/definitions.js +109 -113
  5. package/lib/helpers/browser.d.ts +8 -0
  6. package/lib/helpers/browser.js +14 -11
  7. package/lib/helpers/dates.js +18 -19
  8. package/lib/helpers/debug.js +9 -9
  9. package/lib/helpers/elements-interactions.js +78 -84
  10. package/lib/helpers/fetch.js +82 -89
  11. package/lib/helpers/navigation.js +24 -31
  12. package/lib/helpers/storage.js +10 -12
  13. package/lib/helpers/transactions.js +33 -35
  14. package/lib/helpers/waiting.js +45 -44
  15. package/lib/index.js +15 -82
  16. package/lib/scrapers/amex.js +11 -13
  17. package/lib/scrapers/base-beinleumi-group.js +233 -252
  18. package/lib/scrapers/base-isracard-amex.js +273 -286
  19. package/lib/scrapers/base-scraper-with-browser.d.ts +2 -1
  20. package/lib/scrapers/base-scraper-with-browser.js +240 -269
  21. package/lib/scrapers/base-scraper.js +82 -86
  22. package/lib/scrapers/behatsdaa.js +98 -107
  23. package/lib/scrapers/beinleumi.js +11 -20
  24. package/lib/scrapers/beyahad-bishvilha.js +132 -138
  25. package/lib/scrapers/discount.js +97 -103
  26. package/lib/scrapers/errors.js +22 -25
  27. package/lib/scrapers/factory.js +66 -67
  28. package/lib/scrapers/hapoalim.js +162 -182
  29. package/lib/scrapers/interface.d.ts +12 -0
  30. package/lib/scrapers/interface.js +2 -5
  31. package/lib/scrapers/isracard.js +11 -13
  32. package/lib/scrapers/leumi.js +167 -176
  33. package/lib/scrapers/massad.js +11 -20
  34. package/lib/scrapers/max.js +256 -268
  35. package/lib/scrapers/mercantile.js +14 -20
  36. package/lib/scrapers/mizrahi.js +158 -159
  37. package/lib/scrapers/one-zero-queries.js +4 -7
  38. package/lib/scrapers/one-zero.js +176 -240
  39. package/lib/scrapers/otsar-hahayal.js +11 -20
  40. package/lib/scrapers/pagi.js +11 -20
  41. package/lib/scrapers/union-bank.js +172 -179
  42. package/lib/scrapers/visa-cal.js +254 -263
  43. package/lib/scrapers/yahav.js +190 -211
  44. package/lib/transactions.js +13 -16
  45. package/package.json +12 -14
  46. package/lib/scrapers/amex.test.d.ts +0 -1
  47. package/lib/scrapers/amex.test.js +0 -54
  48. package/lib/scrapers/base-scraper-with-browser.test.d.ts +0 -1
  49. package/lib/scrapers/base-scraper-with-browser.test.js +0 -58
  50. package/lib/scrapers/behatsdaa.test.d.ts +0 -1
  51. package/lib/scrapers/behatsdaa.test.js +0 -50
  52. package/lib/scrapers/beinleumi.test.d.ts +0 -1
  53. package/lib/scrapers/beinleumi.test.js +0 -52
  54. package/lib/scrapers/beyahad-bishvilha.test.d.ts +0 -1
  55. package/lib/scrapers/beyahad-bishvilha.test.js +0 -52
  56. package/lib/scrapers/discount.test.d.ts +0 -1
  57. package/lib/scrapers/discount.test.js +0 -54
  58. package/lib/scrapers/factory.test.d.ts +0 -1
  59. package/lib/scrapers/factory.test.js +0 -19
  60. package/lib/scrapers/hapoalim.test.d.ts +0 -1
  61. package/lib/scrapers/hapoalim.test.js +0 -52
  62. package/lib/scrapers/isracard.test.d.ts +0 -1
  63. package/lib/scrapers/isracard.test.js +0 -54
  64. package/lib/scrapers/leumi.test.d.ts +0 -1
  65. package/lib/scrapers/leumi.test.js +0 -52
  66. package/lib/scrapers/max.test.d.ts +0 -1
  67. package/lib/scrapers/max.test.js +0 -71
  68. package/lib/scrapers/mercantile.test.d.ts +0 -1
  69. package/lib/scrapers/mercantile.test.js +0 -50
  70. package/lib/scrapers/mizrahi.test.d.ts +0 -1
  71. package/lib/scrapers/mizrahi.test.js +0 -58
  72. package/lib/scrapers/one-zero.test.d.ts +0 -1
  73. package/lib/scrapers/one-zero.test.js +0 -56
  74. package/lib/scrapers/otsar-hahayal.test.d.ts +0 -1
  75. package/lib/scrapers/otsar-hahayal.test.js +0 -52
  76. package/lib/scrapers/pagi.test.d.ts +0 -1
  77. package/lib/scrapers/pagi.test.js +0 -52
  78. package/lib/scrapers/union-bank.test.d.ts +0 -1
  79. package/lib/scrapers/union-bank.test.js +0 -52
  80. package/lib/scrapers/visa-cal.test.d.ts +0 -1
  81. package/lib/scrapers/visa-cal.test.js +0 -54
  82. package/lib/scrapers/yahav.test.d.ts +0 -1
  83. package/lib/scrapers/yahav.test.js +0 -54
@@ -1,155 +1,149 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- require("core-js/modules/es.symbol.description.js");
8
- require("core-js/modules/es.array.iterator.js");
9
- require("core-js/modules/es.promise.js");
10
- require("core-js/modules/es.regexp.exec.js");
11
- require("core-js/modules/es.string.replace.js");
12
- var _moment = _interopRequireDefault(require("moment"));
13
- var _constants = require("../constants");
14
- var _debug = require("../helpers/debug");
15
- var _elementsInteractions = require("../helpers/elements-interactions");
16
- var _transactions = require("../helpers/transactions");
17
- var _transactions2 = require("../transactions");
18
- var _baseScraperWithBrowser = require("./base-scraper-with-browser");
19
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
20
- const debug = (0, _debug.getDebug)('beyahadBishvilha');
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const moment_1 = __importDefault(require("moment"));
7
+ const constants_1 = require("../constants");
8
+ const debug_1 = require("../helpers/debug");
9
+ const elements_interactions_1 = require("../helpers/elements-interactions");
10
+ const transactions_1 = require("../helpers/transactions");
11
+ const transactions_2 = require("../transactions");
12
+ const base_scraper_with_browser_1 = require("./base-scraper-with-browser");
13
+ const debug = (0, debug_1.getDebug)('beyahadBishvilha');
21
14
  const DATE_FORMAT = 'DD/MM/YY';
22
15
  const LOGIN_URL = 'https://www.hist.org.il/login';
23
16
  const SUCCESS_URL = 'https://www.hist.org.il/';
24
17
  const CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';
25
18
  function getAmountData(amountStr) {
26
- const amountStrCln = amountStr.replace(',', '');
27
- let currency = null;
28
- let amount = null;
29
- if (amountStrCln.includes(_constants.SHEKEL_CURRENCY_SYMBOL)) {
30
- amount = parseFloat(amountStrCln.replace(_constants.SHEKEL_CURRENCY_SYMBOL, ''));
31
- currency = _constants.SHEKEL_CURRENCY;
32
- } else if (amountStrCln.includes(_constants.DOLLAR_CURRENCY_SYMBOL)) {
33
- amount = parseFloat(amountStrCln.replace(_constants.DOLLAR_CURRENCY_SYMBOL, ''));
34
- currency = _constants.DOLLAR_CURRENCY;
35
- } else if (amountStrCln.includes(_constants.EURO_CURRENCY_SYMBOL)) {
36
- amount = parseFloat(amountStrCln.replace(_constants.EURO_CURRENCY_SYMBOL, ''));
37
- currency = _constants.EURO_CURRENCY;
38
- } else {
39
- const parts = amountStrCln.split(' ');
40
- [currency] = parts;
41
- amount = parseFloat(parts[1]);
42
- }
43
- return {
44
- amount,
45
- currency
46
- };
19
+ const amountStrCln = amountStr.replace(',', '');
20
+ let currency = null;
21
+ let amount = null;
22
+ if (amountStrCln.includes(constants_1.SHEKEL_CURRENCY_SYMBOL)) {
23
+ amount = parseFloat(amountStrCln.replace(constants_1.SHEKEL_CURRENCY_SYMBOL, ''));
24
+ currency = constants_1.SHEKEL_CURRENCY;
25
+ }
26
+ else if (amountStrCln.includes(constants_1.DOLLAR_CURRENCY_SYMBOL)) {
27
+ amount = parseFloat(amountStrCln.replace(constants_1.DOLLAR_CURRENCY_SYMBOL, ''));
28
+ currency = constants_1.DOLLAR_CURRENCY;
29
+ }
30
+ else if (amountStrCln.includes(constants_1.EURO_CURRENCY_SYMBOL)) {
31
+ amount = parseFloat(amountStrCln.replace(constants_1.EURO_CURRENCY_SYMBOL, ''));
32
+ currency = constants_1.EURO_CURRENCY;
33
+ }
34
+ else {
35
+ const parts = amountStrCln.split(' ');
36
+ [currency] = parts;
37
+ amount = parseFloat(parts[1]);
38
+ }
39
+ return {
40
+ amount,
41
+ currency,
42
+ };
47
43
  }
48
44
  function convertTransactions(txns) {
49
- debug(`convert ${txns.length} raw transactions to official Transaction structure`);
50
- return txns.map(txn => {
51
- const chargedAmountTuple = getAmountData(txn.chargedAmount || '');
52
- const txnProcessedDate = (0, _moment.default)(txn.date, DATE_FORMAT);
53
- const result = {
54
- type: _transactions2.TransactionTypes.Normal,
55
- status: _transactions2.TransactionStatuses.Completed,
56
- date: txnProcessedDate.toISOString(),
57
- processedDate: txnProcessedDate.toISOString(),
58
- originalAmount: chargedAmountTuple.amount,
59
- originalCurrency: chargedAmountTuple.currency,
60
- chargedAmount: chargedAmountTuple.amount,
61
- chargedCurrency: chargedAmountTuple.currency,
62
- description: txn.description || '',
63
- memo: '',
64
- identifier: txn.identifier
65
- };
66
- return result;
67
- });
45
+ debug(`convert ${txns.length} raw transactions to official Transaction structure`);
46
+ return txns.map(txn => {
47
+ const chargedAmountTuple = getAmountData(txn.chargedAmount || '');
48
+ const txnProcessedDate = (0, moment_1.default)(txn.date, DATE_FORMAT);
49
+ const result = {
50
+ type: transactions_2.TransactionTypes.Normal,
51
+ status: transactions_2.TransactionStatuses.Completed,
52
+ date: txnProcessedDate.toISOString(),
53
+ processedDate: txnProcessedDate.toISOString(),
54
+ originalAmount: chargedAmountTuple.amount,
55
+ originalCurrency: chargedAmountTuple.currency,
56
+ chargedAmount: chargedAmountTuple.amount,
57
+ chargedCurrency: chargedAmountTuple.currency,
58
+ description: txn.description || '',
59
+ memo: '',
60
+ identifier: txn.identifier,
61
+ };
62
+ return result;
63
+ });
68
64
  }
69
65
  async function fetchTransactions(page, options) {
70
- var _options$outputData$e, _options$outputData;
71
- await page.goto(CARD_URL);
72
- await (0, _elementsInteractions.waitUntilElementFound)(page, '.react-loading.hide', false);
73
- const defaultStartMoment = (0, _moment.default)().subtract(1, 'years');
74
- const startDate = options.startDate || defaultStartMoment.toDate();
75
- const startMoment = _moment.default.max(defaultStartMoment, (0, _moment.default)(startDate));
76
- const accountNumber = await (0, _elementsInteractions.pageEval)(page, '.wallet-details div:nth-of-type(2)', null, element => {
77
- return element.innerText.replace('מספר כרטיס ', '');
78
- });
79
- const balance = await (0, _elementsInteractions.pageEval)(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, element => {
80
- return element.innerText;
81
- });
82
- debug('fetch raw transactions from page');
83
- const rawTransactions = await (0, _elementsInteractions.pageEvalAll)(page, '.transaction-container, .transaction-component-container', [], items => {
84
- return items.map(el => {
85
- const columns = el.querySelectorAll('.transaction-item > span');
86
- if (columns.length === 7) {
87
- return {
88
- date: columns[0].innerText,
89
- identifier: columns[1].innerText,
90
- description: columns[3].innerText,
91
- type: columns[5].innerText,
92
- chargedAmount: columns[6].innerText
93
- };
94
- }
95
- return null;
66
+ await page.goto(CARD_URL);
67
+ await (0, elements_interactions_1.waitUntilElementFound)(page, '.react-loading.hide', false);
68
+ const defaultStartMoment = (0, moment_1.default)().subtract(1, 'years');
69
+ const startDate = options.startDate || defaultStartMoment.toDate();
70
+ const startMoment = moment_1.default.max(defaultStartMoment, (0, moment_1.default)(startDate));
71
+ const accountNumber = await (0, elements_interactions_1.pageEval)(page, '.wallet-details div:nth-of-type(2)', null, element => {
72
+ return element.innerText.replace('מספר כרטיס ', '');
73
+ });
74
+ const balance = await (0, elements_interactions_1.pageEval)(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, element => {
75
+ return element.innerText;
76
+ });
77
+ debug('fetch raw transactions from page');
78
+ const rawTransactions = await (0, elements_interactions_1.pageEvalAll)(page, '.transaction-container, .transaction-component-container', [], items => {
79
+ return items.map(el => {
80
+ const columns = el.querySelectorAll('.transaction-item > span');
81
+ if (columns.length === 7) {
82
+ return {
83
+ date: columns[0].innerText,
84
+ identifier: columns[1].innerText,
85
+ description: columns[3].innerText,
86
+ type: columns[5].innerText,
87
+ chargedAmount: columns[6].innerText,
88
+ };
89
+ }
90
+ return null;
91
+ });
96
92
  });
97
- });
98
- debug(`fetched ${rawTransactions.length} raw transactions from page`);
99
- const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item));
100
- debug('filer out old transactions');
101
- const txns = ((_options$outputData$e = (_options$outputData = options.outputData) === null || _options$outputData === void 0 ? void 0 : _options$outputData.enableTransactionsFilterByDate) !== null && _options$outputData$e !== void 0 ? _options$outputData$e : true) ? (0, _transactions.filterOldTransactions)(accountTransactions, startMoment, false) : accountTransactions;
102
- debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);
103
- return {
104
- accountNumber,
105
- balance: getAmountData(balance).amount,
106
- txns
107
- };
93
+ debug(`fetched ${rawTransactions.length} raw transactions from page`);
94
+ const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item));
95
+ debug('filer out old transactions');
96
+ const txns = (options.outputData?.enableTransactionsFilterByDate ?? true)
97
+ ? (0, transactions_1.filterOldTransactions)(accountTransactions, startMoment, false)
98
+ : accountTransactions;
99
+ debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);
100
+ return {
101
+ accountNumber,
102
+ balance: getAmountData(balance).amount,
103
+ txns,
104
+ };
108
105
  }
109
106
  function getPossibleLoginResults() {
110
- const urls = {};
111
- urls[_baseScraperWithBrowser.LoginResults.Success] = [SUCCESS_URL];
112
- urls[_baseScraperWithBrowser.LoginResults.ChangePassword] = []; // TODO
113
- urls[_baseScraperWithBrowser.LoginResults.InvalidPassword] = []; // TODO
114
- urls[_baseScraperWithBrowser.LoginResults.UnknownError] = []; // TODO
115
- return urls;
107
+ const urls = {};
108
+ urls[base_scraper_with_browser_1.LoginResults.Success] = [SUCCESS_URL];
109
+ urls[base_scraper_with_browser_1.LoginResults.ChangePassword] = []; // TODO
110
+ urls[base_scraper_with_browser_1.LoginResults.InvalidPassword] = []; // TODO
111
+ urls[base_scraper_with_browser_1.LoginResults.UnknownError] = []; // TODO
112
+ return urls;
116
113
  }
117
114
  function createLoginFields(credentials) {
118
- return [{
119
- selector: '#loginId',
120
- value: credentials.id
121
- }, {
122
- selector: '#loginPassword',
123
- value: credentials.password
124
- }];
115
+ return [
116
+ { selector: '#loginId', value: credentials.id },
117
+ { selector: '#loginPassword', value: credentials.password },
118
+ ];
125
119
  }
126
- class BeyahadBishvilhaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
127
- getViewPort() {
128
- return {
129
- width: 1500,
130
- height: 800
131
- };
132
- }
133
- getLoginOptions(credentials) {
134
- return {
135
- loginUrl: LOGIN_URL,
136
- fields: createLoginFields(credentials),
137
- submitButtonSelector: async () => {
138
- const button = await this.page.$('xpath//button[contains(., "התחבר")]');
139
- if (button) {
140
- await button.click();
141
- }
142
- },
143
- possibleResults: getPossibleLoginResults()
144
- };
145
- }
146
- async fetchData() {
147
- const account = await fetchTransactions(this.page, this.options);
148
- return {
149
- success: true,
150
- accounts: [account]
151
- };
152
- }
120
+ class BeyahadBishvilhaScraper extends base_scraper_with_browser_1.BaseScraperWithBrowser {
121
+ getViewPort() {
122
+ return {
123
+ width: 1500,
124
+ height: 800,
125
+ };
126
+ }
127
+ getLoginOptions(credentials) {
128
+ return {
129
+ loginUrl: LOGIN_URL,
130
+ fields: createLoginFields(credentials),
131
+ submitButtonSelector: async () => {
132
+ const button = await this.page.$('xpath//button[contains(., "התחבר")]');
133
+ if (button) {
134
+ await button.click();
135
+ }
136
+ },
137
+ possibleResults: getPossibleLoginResults(),
138
+ };
139
+ }
140
+ async fetchData() {
141
+ const account = await fetchTransactions(this.page, this.options);
142
+ return {
143
+ success: true,
144
+ accounts: [account],
145
+ };
146
+ }
153
147
  }
154
- var _default = exports.default = BeyahadBishvilhaScraper;
155
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_debug","_elementsInteractions","_transactions","_transactions2","_baseScraperWithBrowser","e","__esModule","default","debug","getDebug","DATE_FORMAT","LOGIN_URL","SUCCESS_URL","CARD_URL","getAmountData","amountStr","amountStrCln","replace","currency","amount","includes","SHEKEL_CURRENCY_SYMBOL","parseFloat","SHEKEL_CURRENCY","DOLLAR_CURRENCY_SYMBOL","DOLLAR_CURRENCY","EURO_CURRENCY_SYMBOL","EURO_CURRENCY","parts","split","convertTransactions","txns","length","map","txn","chargedAmountTuple","chargedAmount","txnProcessedDate","moment","date","result","type","TransactionTypes","Normal","status","TransactionStatuses","Completed","toISOString","processedDate","originalAmount","originalCurrency","chargedCurrency","description","memo","identifier","fetchTransactions","page","options","_options$outputData$e","_options$outputData","goto","waitUntilElementFound","defaultStartMoment","subtract","startDate","toDate","startMoment","max","accountNumber","pageEval","element","innerText","balance","rawTransactions","pageEvalAll","items","el","columns","querySelectorAll","accountTransactions","filter","item","outputData","enableTransactionsFilterByDate","filterOldTransactions","substring","getPossibleLoginResults","urls","LoginResults","Success","ChangePassword","InvalidPassword","UnknownError","createLoginFields","credentials","selector","value","id","password","BeyahadBishvilhaScraper","BaseScraperWithBrowser","getViewPort","width","height","getLoginOptions","loginUrl","fields","submitButtonSelector","button","$","click","possibleResults","fetchData","account","success","accounts","_default","exports"],"sources":["../../src/scrapers/beyahad-bishvilha.ts"],"sourcesContent":["import moment from 'moment';\nimport { type Page } from 'puppeteer';\nimport {\n  DOLLAR_CURRENCY,\n  DOLLAR_CURRENCY_SYMBOL, EURO_CURRENCY,\n  EURO_CURRENCY_SYMBOL,\n  SHEKEL_CURRENCY,\n  SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\nimport { getDebug } from '../helpers/debug';\nimport { pageEval, pageEvalAll, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { TransactionStatuses, TransactionTypes, type Transaction } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { type ScraperOptions } from './interface';\n\nconst debug = getDebug('beyahadBishvilha');\n\nconst DATE_FORMAT = 'DD/MM/YY';\nconst LOGIN_URL = 'https://www.hist.org.il/login';\nconst SUCCESS_URL = 'https://www.hist.org.il/';\nconst CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';\n\ninterface ScrapedTransaction {\n  date: string;\n  description: string;\n  type: string;\n  chargedAmount: string;\n  identifier: string;\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCln = amountStr.replace(',', '');\n  let currency: string | null = null;\n  let amount: number | null = null;\n  if (amountStrCln.includes(SHEKEL_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(SHEKEL_CURRENCY_SYMBOL, ''));\n    currency = SHEKEL_CURRENCY;\n  } else if (amountStrCln.includes(DOLLAR_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(DOLLAR_CURRENCY_SYMBOL, ''));\n    currency = DOLLAR_CURRENCY;\n  } else if (amountStrCln.includes(EURO_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(EURO_CURRENCY_SYMBOL, ''));\n    currency = EURO_CURRENCY;\n  } else {\n    const parts = amountStrCln.split(' ');\n    [currency] = parts;\n    amount = parseFloat(parts[1]);\n  }\n\n  return {\n    amount,\n    currency,\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[]): Transaction[] {\n  debug(`convert ${txns.length} raw transactions to official Transaction structure`);\n  return txns.map((txn) => {\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n    const txnProcessedDate = moment(txn.date, DATE_FORMAT);\n\n    const result: Transaction = {\n      type: TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: txnProcessedDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: chargedAmountTuple.amount,\n      originalCurrency: chargedAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: '',\n      identifier: txn.identifier,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(page: Page, options: ScraperOptions) {\n  await page.goto(CARD_URL);\n  await waitUntilElementFound(page, '.react-loading.hide', false);\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const accountNumber = await pageEval(page, '.wallet-details div:nth-of-type(2)', null, (element) => {\n    return (element as any).innerText.replace('מספר כרטיס ', '');\n  });\n\n  const balance = await pageEval(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, (element) => {\n    return (element as any).innerText;\n  });\n\n  debug('fetch raw transactions from page');\n\n  const rawTransactions: (ScrapedTransaction | null)[] = await pageEvalAll<(ScrapedTransaction | null)[]>(page, '.transaction-container, .transaction-component-container', [], (items) => {\n    return (items).map((el) => {\n      const columns: NodeListOf<HTMLSpanElement> = el.querySelectorAll('.transaction-item > span');\n      if (columns.length === 7) {\n        return {\n          date: columns[0].innerText,\n          identifier: columns[1].innerText,\n          description: columns[3].innerText,\n          type: columns[5].innerText,\n          chargedAmount: columns[6].innerText,\n        };\n      }\n      return null;\n    });\n  });\n  debug(`fetched ${rawTransactions.length} raw transactions from page`);\n\n  const accountTransactions = convertTransactions(rawTransactions.filter((item) => !!item) as ScrapedTransaction[]);\n\n  debug('filer out old transactions');\n  const txns = (options.outputData?.enableTransactionsFilterByDate ?? true) ?\n    filterOldTransactions(accountTransactions, startMoment, false) :\n    accountTransactions;\n  debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);\n\n  return {\n    accountNumber,\n    balance: getAmountData(balance).amount,\n    txns,\n  };\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = []; // TODO\n  urls[LoginResults.InvalidPassword] = []; // TODO\n  urls[LoginResults.UnknownError] = []; // TODO\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#loginId', value: credentials.id },\n    { selector: '#loginPassword', value: credentials.password },\n  ];\n}\n\ntype ScraperSpecificCredentials = { id: string, password: string };\n\nclass BeyahadBishvilhaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  protected getViewPort(): { width: number, height: number } {\n    return {\n      width: 1500,\n      height: 800,\n    };\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: async () => {\n        const button = await this.page.$('xpath//button[contains(., \"התחבר\")]');\n        if (button) {\n          await button.click();\n        }\n      },\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    const account = await fetchTransactions(this.page, this.options);\n    return {\n      success: true,\n      accounts: [account],\n    };\n  }\n}\n\nexport default BeyahadBishvilhaScraper;\n"],"mappings":"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","ignoreList":[]}
148
+ exports.default = BeyahadBishvilhaScraper;
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beyahad-bishvilha.js","sourceRoot":"","sources":["../../src/scrapers/beyahad-bishvilha.ts"],"names":[],"mappings":"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","sourcesContent":["import moment from 'moment';\nimport { type Page } from 'puppeteer';\nimport {\n  DOLLAR_CURRENCY,\n  DOLLAR_CURRENCY_SYMBOL,\n  EURO_CURRENCY,\n  EURO_CURRENCY_SYMBOL,\n  SHEKEL_CURRENCY,\n  SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\nimport { getDebug } from '../helpers/debug';\nimport { pageEval, pageEvalAll, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { TransactionStatuses, TransactionTypes, type Transaction } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { type ScraperOptions } from './interface';\n\nconst debug = getDebug('beyahadBishvilha');\n\nconst DATE_FORMAT = 'DD/MM/YY';\nconst LOGIN_URL = 'https://www.hist.org.il/login';\nconst SUCCESS_URL = 'https://www.hist.org.il/';\nconst CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';\n\ninterface ScrapedTransaction {\n  date: string;\n  description: string;\n  type: string;\n  chargedAmount: string;\n  identifier: string;\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCln = amountStr.replace(',', '');\n  let currency: string | null = null;\n  let amount: number | null = null;\n  if (amountStrCln.includes(SHEKEL_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(SHEKEL_CURRENCY_SYMBOL, ''));\n    currency = SHEKEL_CURRENCY;\n  } else if (amountStrCln.includes(DOLLAR_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(DOLLAR_CURRENCY_SYMBOL, ''));\n    currency = DOLLAR_CURRENCY;\n  } else if (amountStrCln.includes(EURO_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(EURO_CURRENCY_SYMBOL, ''));\n    currency = EURO_CURRENCY;\n  } else {\n    const parts = amountStrCln.split(' ');\n    [currency] = parts;\n    amount = parseFloat(parts[1]);\n  }\n\n  return {\n    amount,\n    currency,\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[]): Transaction[] {\n  debug(`convert ${txns.length} raw transactions to official Transaction structure`);\n  return txns.map(txn => {\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n    const txnProcessedDate = moment(txn.date, DATE_FORMAT);\n\n    const result: Transaction = {\n      type: TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: txnProcessedDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: chargedAmountTuple.amount,\n      originalCurrency: chargedAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: '',\n      identifier: txn.identifier,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(page: Page, options: ScraperOptions) {\n  await page.goto(CARD_URL);\n  await waitUntilElementFound(page, '.react-loading.hide', false);\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const accountNumber = await pageEval(page, '.wallet-details div:nth-of-type(2)', null, element => {\n    return (element as any).innerText.replace('מספר כרטיס ', '');\n  });\n\n  const balance = await pageEval(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, element => {\n    return (element as any).innerText;\n  });\n\n  debug('fetch raw transactions from page');\n\n  const rawTransactions: (ScrapedTransaction | null)[] = await pageEvalAll<(ScrapedTransaction | null)[]>(\n    page,\n    '.transaction-container, .transaction-component-container',\n    [],\n    items => {\n      return items.map(el => {\n        const columns: NodeListOf<HTMLSpanElement> = el.querySelectorAll('.transaction-item > span');\n        if (columns.length === 7) {\n          return {\n            date: columns[0].innerText,\n            identifier: columns[1].innerText,\n            description: columns[3].innerText,\n            type: columns[5].innerText,\n            chargedAmount: columns[6].innerText,\n          };\n        }\n        return null;\n      });\n    },\n  );\n  debug(`fetched ${rawTransactions.length} raw transactions from page`);\n\n  const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item) as ScrapedTransaction[]);\n\n  debug('filer out old transactions');\n  const txns =\n    (options.outputData?.enableTransactionsFilterByDate ?? true)\n      ? filterOldTransactions(accountTransactions, startMoment, false)\n      : accountTransactions;\n  debug(\n    `found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`,\n  );\n\n  return {\n    accountNumber,\n    balance: getAmountData(balance).amount,\n    txns,\n  };\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = []; // TODO\n  urls[LoginResults.InvalidPassword] = []; // TODO\n  urls[LoginResults.UnknownError] = []; // TODO\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#loginId', value: credentials.id },\n    { selector: '#loginPassword', value: credentials.password },\n  ];\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string };\n\nclass BeyahadBishvilhaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  protected getViewPort(): { width: number; height: number } {\n    return {\n      width: 1500,\n      height: 800,\n    };\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: async () => {\n        const button = await this.page.$('xpath//button[contains(., \"התחבר\")]');\n        if (button) {\n          await button.click();\n        }\n      },\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    const account = await fetchTransactions(this.page, this.options);\n    return {\n      success: true,\n      accounts: [account],\n    };\n  }\n}\n\nexport default BeyahadBishvilhaScraper;\n"]}