mirror of
https://github.com/orangecoding/fredy.git
synced 2026-06-16 12:31:07 +00:00
Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9db1ffd8eb | ||
|
|
1cb79d1287 | ||
|
|
212d6e0367 | ||
|
|
97cb6fa5eb | ||
|
|
8d2cc7f3e0 | ||
|
|
3de81903a1 | ||
|
|
1ad79230c2 | ||
|
|
fb19c52b0f | ||
|
|
db12d33910 | ||
|
|
f1c3106ae4 |
281
.eslintrc.cjs
281
.eslintrc.cjs
@@ -1,281 +0,0 @@
|
|||||||
module.exports = {
|
|
||||||
env: {
|
|
||||||
es2021: true,
|
|
||||||
node: true,
|
|
||||||
browser: true,
|
|
||||||
mocha: true,
|
|
||||||
},
|
|
||||||
parser: '@babel/eslint-parser',
|
|
||||||
extends: ['eslint:recommended', 'prettier'],
|
|
||||||
plugins: ['react'],
|
|
||||||
globals: {
|
|
||||||
Promise: false,
|
|
||||||
describe: true,
|
|
||||||
after: true,
|
|
||||||
it: true,
|
|
||||||
fetch: true,
|
|
||||||
},
|
|
||||||
parserOptions: {
|
|
||||||
sourceType: 'module',
|
|
||||||
},
|
|
||||||
rules: {
|
|
||||||
eqeqeq: [2, 'allow-null'],
|
|
||||||
|
|
||||||
// ###########################################################
|
|
||||||
// ### Semantics / Performance impacting
|
|
||||||
// ###########################################################
|
|
||||||
// babel inserts `'use strict';` for us
|
|
||||||
strict: 0,
|
|
||||||
|
|
||||||
'no-redeclare': [2, { builtinGlobals: false }],
|
|
||||||
|
|
||||||
// If a class method does not use this, it can safely be made a static function.
|
|
||||||
// http://eslint.org/docs/rules/class-methods-use-this
|
|
||||||
'class-methods-use-this': ['off'],
|
|
||||||
|
|
||||||
// ###########################################################
|
|
||||||
// ### Style
|
|
||||||
// ###########################################################
|
|
||||||
indent: ['off', 2],
|
|
||||||
'linebreak-style': ['error', 'unix'],
|
|
||||||
quotes: ['error', 'single', { avoidEscape: true, allowTemplateLiterals: true }],
|
|
||||||
semi: ['error', 'always'],
|
|
||||||
'no-console': ['error', { allow: ['warn', 'error'] }],
|
|
||||||
|
|
||||||
// ###########################################################
|
|
||||||
// ### React
|
|
||||||
// ###########################################################
|
|
||||||
// Specify whether double or single quotes should be used in JSX attributes
|
|
||||||
// http://eslint.org/docs/rules/jsx-quotes
|
|
||||||
'jsx-quotes': ['error', 'prefer-double'],
|
|
||||||
|
|
||||||
// Prevent missing displayName in a React component definition
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/display-name.md
|
|
||||||
'react/display-name': ['off'],
|
|
||||||
|
|
||||||
// Forbid certain propTypes (any, array, object)
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/forbid-prop-types.md
|
|
||||||
'react/forbid-prop-types': 'off',
|
|
||||||
|
|
||||||
// Validate closing bracket location in JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-closing-bracket-location.md
|
|
||||||
'react/jsx-closing-bracket-location': ['off'],
|
|
||||||
|
|
||||||
// Enforce or disallow spaces inside of curly braces in JSX attributes
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-curly-spacing.md
|
|
||||||
'react/jsx-curly-spacing': ['off'],
|
|
||||||
|
|
||||||
// Enforce event handler naming conventions in JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-handler-names.md
|
|
||||||
'react/jsx-handler-names': [
|
|
||||||
'off',
|
|
||||||
{
|
|
||||||
eventHandlerPrefix: 'handle',
|
|
||||||
eventHandlerPropPrefix: 'on',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
// Validate props indentation in JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-indent-props.md
|
|
||||||
'react/jsx-indent-props': 'off',
|
|
||||||
|
|
||||||
// Validate JSX has key prop when in array or iterator
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-key.md
|
|
||||||
'react/jsx-key': 'off',
|
|
||||||
|
|
||||||
// Limit maximum of props on a single line in JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-max-props-per-line.md
|
|
||||||
'react/jsx-max-props-per-line': ['off'],
|
|
||||||
|
|
||||||
// Prevent usage of .bind() in JSX props
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-no-bind.md
|
|
||||||
'react/jsx-no-bind': [
|
|
||||||
'error',
|
|
||||||
{
|
|
||||||
ignoreRefs: true,
|
|
||||||
allowArrowFunctions: true,
|
|
||||||
allowBind: false,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
// Prevent duplicate props in JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-no-duplicate-props.md
|
|
||||||
'react/jsx-no-duplicate-props': ['error', { ignoreCase: true }],
|
|
||||||
|
|
||||||
// Prevent usage of unwrapped JSX strings
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-no-literals.md
|
|
||||||
'react/jsx-no-literals': 'off',
|
|
||||||
|
|
||||||
// Disallow undeclared variables in JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-no-undef.md
|
|
||||||
'react/jsx-no-undef': 'error',
|
|
||||||
|
|
||||||
// Enforce PascalCase for user-defined JSX components
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-pascal-case.md
|
|
||||||
'react/jsx-pascal-case': [
|
|
||||||
'error',
|
|
||||||
{
|
|
||||||
allowAllCaps: true,
|
|
||||||
ignore: [],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
// Enforce propTypes declarations alphabetical sorting
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/sort-prop-types.md
|
|
||||||
'react/sort-prop-types': [
|
|
||||||
'off',
|
|
||||||
{
|
|
||||||
ignoreCase: true,
|
|
||||||
callbacksLast: false,
|
|
||||||
requiredFirst: false,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
// Deprecated in favor of react/jsx-sort-props
|
|
||||||
'react/jsx-sort-prop-types': 'off',
|
|
||||||
|
|
||||||
// Enforce props alphabetical sorting
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-sort-props.md
|
|
||||||
'react/jsx-sort-props': 'off',
|
|
||||||
|
|
||||||
// Prevent React to be incorrectly marked as unused
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-uses-react.md
|
|
||||||
'react/jsx-uses-react': 'error',
|
|
||||||
|
|
||||||
// Prevent variables used in JSX to be incorrectly marked as unused
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-uses-vars.md
|
|
||||||
'react/jsx-uses-vars': 'error',
|
|
||||||
|
|
||||||
// Prevent usage of dangerous JSX properties
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-danger.md
|
|
||||||
'react/no-danger': 'warn',
|
|
||||||
|
|
||||||
// Prevent usage of deprecated methods
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-deprecated.md
|
|
||||||
'react/no-deprecated': ['error'],
|
|
||||||
|
|
||||||
// Prevent usage of setState in componentDidMount
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-did-mount-set-state.md
|
|
||||||
'react/no-did-mount-set-state': ['error'],
|
|
||||||
|
|
||||||
// Prevent usage of setState in componentDidUpdate
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-did-update-set-state.md
|
|
||||||
'react/no-did-update-set-state': ['warn'],
|
|
||||||
|
|
||||||
// Prevent direct mutation of this.state
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-direct-mutation-state.md
|
|
||||||
'react/no-direct-mutation-state': 'off',
|
|
||||||
|
|
||||||
// Prevent usage of isMounted
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-is-mounted.md
|
|
||||||
'react/no-is-mounted': 'error',
|
|
||||||
|
|
||||||
// Prevent usage of setState
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-set-state.md
|
|
||||||
'react/no-set-state': 'off',
|
|
||||||
|
|
||||||
// Prevent using string references
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-string-refs.md
|
|
||||||
'react/no-string-refs': 'warn',
|
|
||||||
|
|
||||||
// Prevent usage of unknown DOM property
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-unknown-property.md
|
|
||||||
'react/no-unknown-property': 'error',
|
|
||||||
|
|
||||||
// Prevent missing props validation in a React component definition
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/prop-types.md
|
|
||||||
'react/prop-types': ['error', { ignore: [], customValidators: [], skipUndeclared: true }],
|
|
||||||
|
|
||||||
// Prevent missing React when using JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/react-in-jsx-scope.md
|
|
||||||
'react/react-in-jsx-scope': 'error',
|
|
||||||
|
|
||||||
// Restrict file extensions that may be required
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/require-extension.md
|
|
||||||
// deprecated in favor of import/extensions
|
|
||||||
'react/require-extension': ['off', { extensions: ['.jsx', '.js'] }],
|
|
||||||
|
|
||||||
// Require render() methods to return something
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/require-render-return.md
|
|
||||||
'react/require-render-return': 'error',
|
|
||||||
|
|
||||||
// Prevent extra closing tags for components without children
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/self-closing-comp.md
|
|
||||||
'react/self-closing-comp': 'warn',
|
|
||||||
|
|
||||||
// Enforce component methods order
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/sort-comp.md
|
|
||||||
'react/sort-comp': 'off',
|
|
||||||
|
|
||||||
// Prevent missing parentheses around multilines JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-wrap-multilines.md
|
|
||||||
'react/jsx-wrap-multilines': [
|
|
||||||
'warn',
|
|
||||||
{
|
|
||||||
declaration: true,
|
|
||||||
assignment: true,
|
|
||||||
return: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
'react/wrap-multilines': 'off', // deprecated version
|
|
||||||
|
|
||||||
// Require that the first prop in a JSX element be on a new line when the element is multiline
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-first-prop-new-line.md
|
|
||||||
'react/jsx-first-prop-new-line': ['off'],
|
|
||||||
|
|
||||||
// Enforce spacing around jsx equals signs
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-equals-spacing.md
|
|
||||||
'react/jsx-equals-spacing': ['warn', 'never'],
|
|
||||||
|
|
||||||
// Disallow target="_blank" on links
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-no-target-blank.md
|
|
||||||
'react/jsx-no-target-blank': 'error',
|
|
||||||
|
|
||||||
// only .jsx files may have JSX
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-filename-extension.md
|
|
||||||
'react/jsx-filename-extension': ['error', { extensions: ['.jsx'] }],
|
|
||||||
|
|
||||||
// prevent accidental JS comments from being injected into JSX as text
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-no-comment-textnodes.md
|
|
||||||
'react/jsx-no-comment-textnodes': 'error',
|
|
||||||
'react/no-comment-textnodes': 'off', // deprecated version
|
|
||||||
|
|
||||||
// disallow using React.render/ReactDOM.render's return value
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-render-return-value.md
|
|
||||||
'react/no-render-return-value': 'error',
|
|
||||||
|
|
||||||
// require a shouldComponentUpdate method, or PureRenderMixin
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/require-optimization.md
|
|
||||||
'react/require-optimization': ['off', { allowDecorators: [] }],
|
|
||||||
|
|
||||||
// warn against using findDOMNode()
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-find-dom-node.md
|
|
||||||
'react/no-find-dom-node': 'warn',
|
|
||||||
|
|
||||||
// Forbid certain props on Components
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/forbid-component-props.md
|
|
||||||
'react/forbid-component-props': ['off', { forbid: [] }],
|
|
||||||
|
|
||||||
// Prevent problem with children and props.dangerouslySetInnerHTML
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-danger-with-children.md
|
|
||||||
'react/no-danger-with-children': 'error',
|
|
||||||
|
|
||||||
// Prevent unused propType definitions
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-unused-prop-types.md
|
|
||||||
'react/no-unused-prop-types': [
|
|
||||||
'warn',
|
|
||||||
{
|
|
||||||
customValidators: [],
|
|
||||||
skipShapeProps: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
// Require style prop value be an object or var
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/style-prop-object.md
|
|
||||||
'react/style-prop-object': 'error',
|
|
||||||
|
|
||||||
// Prevent passing of children as props
|
|
||||||
// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-children-prop.md
|
|
||||||
'react/no-children-prop': 'warn',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
145
eslint.config.js
Normal file
145
eslint.config.js
Normal file
@@ -0,0 +1,145 @@
|
|||||||
|
// eslint.config.js
|
||||||
|
import js from '@eslint/js';
|
||||||
|
import prettier from 'eslint-config-prettier';
|
||||||
|
import globals from 'globals';
|
||||||
|
import react from 'eslint-plugin-react';
|
||||||
|
import babelParser from '@babel/eslint-parser';
|
||||||
|
|
||||||
|
export default [
|
||||||
|
js.configs.recommended,
|
||||||
|
prettier,
|
||||||
|
{
|
||||||
|
languageOptions: {
|
||||||
|
parser: babelParser,
|
||||||
|
sourceType: 'module',
|
||||||
|
ecmaVersion: 2021,
|
||||||
|
globals: {
|
||||||
|
...globals.browser,
|
||||||
|
...globals.node,
|
||||||
|
...globals.mocha,
|
||||||
|
Promise: 'readonly',
|
||||||
|
fetch: 'readonly',
|
||||||
|
describe: 'readonly',
|
||||||
|
after: 'readonly',
|
||||||
|
it: 'readonly',
|
||||||
|
},
|
||||||
|
parserOptions: {
|
||||||
|
requireConfigFile: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
plugins: {
|
||||||
|
react,
|
||||||
|
},
|
||||||
|
rules: {
|
||||||
|
eqeqeq: [2, 'allow-null'],
|
||||||
|
|
||||||
|
// Semantics / Performance impacting
|
||||||
|
strict: 0,
|
||||||
|
'no-redeclare': [2, { builtinGlobals: false }],
|
||||||
|
'class-methods-use-this': 'off',
|
||||||
|
|
||||||
|
// Style
|
||||||
|
indent: ['off', 2],
|
||||||
|
'linebreak-style': ['error', 'unix'],
|
||||||
|
quotes: ['error', 'single', { avoidEscape: true, allowTemplateLiterals: true }],
|
||||||
|
semi: ['error', 'always'],
|
||||||
|
'no-console': ['error', { allow: ['warn', 'error'] }],
|
||||||
|
|
||||||
|
// React
|
||||||
|
'jsx-quotes': ['error', 'prefer-double'],
|
||||||
|
'react/display-name': 'off',
|
||||||
|
'react/forbid-prop-types': 'off',
|
||||||
|
'react/jsx-closing-bracket-location': 'off',
|
||||||
|
'react/jsx-curly-spacing': 'off',
|
||||||
|
'react/jsx-handler-names': [
|
||||||
|
'off',
|
||||||
|
{
|
||||||
|
eventHandlerPrefix: 'handle',
|
||||||
|
eventHandlerPropPrefix: 'on',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
'react/jsx-indent-props': 'off',
|
||||||
|
'react/jsx-key': 'off',
|
||||||
|
'react/jsx-max-props-per-line': 'off',
|
||||||
|
'react/jsx-no-bind': [
|
||||||
|
'error',
|
||||||
|
{
|
||||||
|
ignoreRefs: true,
|
||||||
|
allowArrowFunctions: true,
|
||||||
|
allowBind: false,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
'react/jsx-no-duplicate-props': ['error', { ignoreCase: true }],
|
||||||
|
'react/jsx-no-literals': 'off',
|
||||||
|
'react/jsx-no-undef': 'error',
|
||||||
|
'react/jsx-pascal-case': [
|
||||||
|
'error',
|
||||||
|
{
|
||||||
|
allowAllCaps: true,
|
||||||
|
ignore: [],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
'react/sort-prop-types': [
|
||||||
|
'off',
|
||||||
|
{
|
||||||
|
ignoreCase: true,
|
||||||
|
callbacksLast: false,
|
||||||
|
requiredFirst: false,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
'react/jsx-sort-prop-types': 'off',
|
||||||
|
'react/jsx-sort-props': 'off',
|
||||||
|
'react/jsx-uses-react': 'error',
|
||||||
|
'react/jsx-uses-vars': 'error',
|
||||||
|
'react/no-danger': 'warn',
|
||||||
|
'react/no-deprecated': 'error',
|
||||||
|
'react/no-did-mount-set-state': 'error',
|
||||||
|
'react/no-did-update-set-state': 'warn',
|
||||||
|
'react/no-direct-mutation-state': 'off',
|
||||||
|
'react/no-is-mounted': 'error',
|
||||||
|
'react/no-set-state': 'off',
|
||||||
|
'react/no-string-refs': 'warn',
|
||||||
|
'react/no-unknown-property': 'error',
|
||||||
|
'react/prop-types': ['error', { ignore: [], customValidators: [], skipUndeclared: true }],
|
||||||
|
'react/react-in-jsx-scope': 'error',
|
||||||
|
'react/require-extension': 'off',
|
||||||
|
'react/require-render-return': 'error',
|
||||||
|
'react/self-closing-comp': 'warn',
|
||||||
|
'react/sort-comp': 'off',
|
||||||
|
'react/jsx-wrap-multilines': [
|
||||||
|
'warn',
|
||||||
|
{
|
||||||
|
declaration: true,
|
||||||
|
assignment: true,
|
||||||
|
return: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
'react/wrap-multilines': 'off',
|
||||||
|
'react/jsx-first-prop-new-line': 'off',
|
||||||
|
'react/jsx-equals-spacing': ['warn', 'never'],
|
||||||
|
'react/jsx-no-target-blank': 'error',
|
||||||
|
'react/jsx-filename-extension': ['error', { extensions: ['.jsx'] }],
|
||||||
|
'react/jsx-no-comment-textnodes': 'error',
|
||||||
|
'react/no-comment-textnodes': 'off',
|
||||||
|
'react/no-render-return-value': 'error',
|
||||||
|
'react/require-optimization': ['off', { allowDecorators: [] }],
|
||||||
|
'react/no-find-dom-node': 'warn',
|
||||||
|
'react/forbid-component-props': ['off', { forbid: [] }],
|
||||||
|
'react/no-danger-with-children': 'error',
|
||||||
|
'react/no-unused-prop-types': [
|
||||||
|
'warn',
|
||||||
|
{
|
||||||
|
customValidators: [],
|
||||||
|
skipShapeProps: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
'react/style-prop-object': 'error',
|
||||||
|
'react/no-children-prop': 'warn',
|
||||||
|
},
|
||||||
|
settings: {
|
||||||
|
react: {
|
||||||
|
version: 'detect',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
];
|
||||||
@@ -59,9 +59,7 @@ class FredyRuntime {
|
|||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
reject(err);
|
reject(err);
|
||||||
/* eslint-disable no-console */
|
|
||||||
console.error(err);
|
console.error(err);
|
||||||
/* eslint-enable no-console */
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,7 +18,6 @@ export const send = ({ serviceName, newListings, notificationConfig, jobKey }) =
|
|||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
return Promise.all(promises);
|
return Promise.all(promises);
|
||||||
};
|
};
|
||||||
export const config = {
|
export const config = {
|
||||||
|
|||||||
@@ -113,9 +113,26 @@ export const config = {
|
|||||||
description: 'MailJet is being used to send new listings via mail.',
|
description: 'MailJet is being used to send new listings via mail.',
|
||||||
readme: markdown2Html('lib/notification/adapter/mailJet.md'),
|
readme: markdown2Html('lib/notification/adapter/mailJet.md'),
|
||||||
fields: {
|
fields: {
|
||||||
apiPublicKey: { type: 'text', label: 'Public Api Key' },
|
apiPublicKey: {
|
||||||
apiPrivateKey: { type: 'text', label: 'Private Api Key' },
|
type: 'text',
|
||||||
receiver: { type: 'email', label: 'Receiver Email' },
|
label: 'Public Api Key',
|
||||||
from: { type: 'email', label: 'Sender email' },
|
description: 'The public api key needed to access this service.',
|
||||||
|
},
|
||||||
|
apiPrivateKey: {
|
||||||
|
type: 'text',
|
||||||
|
label: 'Private Api Key',
|
||||||
|
description: 'The private api key needed to access this service.',
|
||||||
|
},
|
||||||
|
receiver: {
|
||||||
|
type: 'email',
|
||||||
|
label: 'Receiver Email',
|
||||||
|
description: 'The email address (single one) which Fredy is using to send notifications to.',
|
||||||
|
},
|
||||||
|
from: {
|
||||||
|
type: 'email',
|
||||||
|
label: 'Sender email',
|
||||||
|
description:
|
||||||
|
'The email address from which Fredy send email. Beware, this email address needs to be verified by Sendgrid.',
|
||||||
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ let appliedBlackList = [];
|
|||||||
function normalize(o) {
|
function normalize(o) {
|
||||||
const size = o.size != null ? o.size.replace('Wohnfläche ', '') : 'N/A m²';
|
const size = o.size != null ? o.size.replace('Wohnfläche ', '') : 'N/A m²';
|
||||||
const price = o.price.replace('Kaufpreis ', '');
|
const price = o.price.replace('Kaufpreis ', '');
|
||||||
const address = o.address.split(' • ')[o.address.split(' • ').length - 1];
|
const address = o.address?.split(' • ')?.pop() ?? null;
|
||||||
const title = o.title || 'No title available';
|
const title = o.title || 'No title available';
|
||||||
const link = config.url;
|
const link = config.url;
|
||||||
const id = buildHash(title, price);
|
const id = buildHash(title, price);
|
||||||
|
|||||||
@@ -62,7 +62,7 @@ async function getListings(url) {
|
|||||||
.map((expose) => {
|
.map((expose) => {
|
||||||
const item = expose.item;
|
const item = expose.item;
|
||||||
const [price, size] = item.attributes;
|
const [price, size] = item.attributes;
|
||||||
const { preview: image } = item.titlePicture;
|
const image = item?.titlePicture?.preview ?? null;
|
||||||
return {
|
return {
|
||||||
id: item.id,
|
id: item.id,
|
||||||
price: price?.value,
|
price: price?.value,
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ export function parse(crawlContainer, crawlFields, text, url) {
|
|||||||
if (fieldSelector.includes('|')) {
|
if (fieldSelector.includes('|')) {
|
||||||
/* eslint-disable no-unused-vars */
|
/* eslint-disable no-unused-vars */
|
||||||
const [_, ...modifiers] = fieldSelector.split('|').map((s) => s.trim());
|
const [_, ...modifiers] = fieldSelector.split('|').map((s) => s.trim());
|
||||||
/* eslint-disable no-unused-vars */
|
/* eslint-enable no-unused-vars */
|
||||||
value = applyModifiers(value, modifiers);
|
value = applyModifiers(value, modifiers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
24
package.json
24
package.json
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "fredy",
|
"name": "fredy",
|
||||||
"version": "11.4.0",
|
"version": "11.4.4",
|
||||||
"description": "[F]ind [R]eal [E]states [d]amn eas[y].",
|
"description": "[F]ind [R]eal [E]states [d]amn eas[y].",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"prepare": "husky",
|
"prepare": "husky",
|
||||||
@@ -11,7 +11,7 @@
|
|||||||
"build:frontend": "vite build",
|
"build:frontend": "vite build",
|
||||||
"format": "prettier --write \"**/*.js\"",
|
"format": "prettier --write \"**/*.js\"",
|
||||||
"format:check": "prettier --check \"**/*.js\"",
|
"format:check": "prettier --check \"**/*.js\"",
|
||||||
"test": "mocha --loader=esmock --timeout 3000000 test/**/*.test.js",
|
"test": "mocha --loader=esmock --timeout 60000 test/**/*.test.js",
|
||||||
"lint": "eslint .",
|
"lint": "eslint .",
|
||||||
"lint:fix": "yarn lint --fix"
|
"lint:fix": "yarn lint --fix"
|
||||||
},
|
},
|
||||||
@@ -58,8 +58,8 @@
|
|||||||
"@rematch/core": "2.2.0",
|
"@rematch/core": "2.2.0",
|
||||||
"@rematch/loading": "2.1.2",
|
"@rematch/loading": "2.1.2",
|
||||||
"@sendgrid/mail": "8.1.5",
|
"@sendgrid/mail": "8.1.5",
|
||||||
"@vitejs/plugin-react": "4.7.0",
|
"@vitejs/plugin-react": "5.0.2",
|
||||||
"better-sqlite3": "^11.10.0",
|
"better-sqlite3": "^12.2.0",
|
||||||
"body-parser": "2.2.0",
|
"body-parser": "2.2.0",
|
||||||
"cheerio": "^1.1.2",
|
"cheerio": "^1.1.2",
|
||||||
"cookie-session": "2.1.1",
|
"cookie-session": "2.1.1",
|
||||||
@@ -67,15 +67,15 @@
|
|||||||
"highcharts": "12.3.0",
|
"highcharts": "12.3.0",
|
||||||
"highcharts-react-official": "3.2.2",
|
"highcharts-react-official": "3.2.2",
|
||||||
"lodash": "4.17.21",
|
"lodash": "4.17.21",
|
||||||
"lowdb": "6.0.1",
|
"lowdb": "7.0.1",
|
||||||
"markdown": "^0.5.0",
|
"markdown": "^0.5.0",
|
||||||
"mixpanel": "^0.18.1",
|
"mixpanel": "^0.18.1",
|
||||||
"nanoid": "5.1.5",
|
"nanoid": "5.1.5",
|
||||||
"node-fetch": "3.3.2",
|
"node-fetch": "3.3.2",
|
||||||
"node-mailjet": "6.0.9",
|
"node-mailjet": "6.0.9",
|
||||||
"p-throttle": "^7.0.0",
|
"p-throttle": "^8.0.0",
|
||||||
"package-up": "^5.0.0",
|
"package-up": "^5.0.0",
|
||||||
"puppeteer": "^24.17.0",
|
"puppeteer": "^24.17.1",
|
||||||
"puppeteer-extra": "^3.3.6",
|
"puppeteer-extra": "^3.3.6",
|
||||||
"puppeteer-extra-plugin-stealth": "^2.11.2",
|
"puppeteer-extra-plugin-stealth": "^2.11.2",
|
||||||
"query-string": "9.2.2",
|
"query-string": "9.2.2",
|
||||||
@@ -98,16 +98,16 @@
|
|||||||
"@babel/eslint-parser": "7.28.0",
|
"@babel/eslint-parser": "7.28.0",
|
||||||
"@babel/preset-env": "7.28.3",
|
"@babel/preset-env": "7.28.3",
|
||||||
"@babel/preset-react": "7.27.1",
|
"@babel/preset-react": "7.27.1",
|
||||||
"chai": "5.2.1",
|
"chai": "6.0.1",
|
||||||
"eslint": "8.56.0",
|
"eslint": "9.34.0",
|
||||||
"eslint-config-prettier": "8.8.0",
|
"eslint-config-prettier": "10.1.8",
|
||||||
"eslint-plugin-react": "7.37.5",
|
"eslint-plugin-react": "7.37.5",
|
||||||
"esmock": "2.7.1",
|
"esmock": "2.7.1",
|
||||||
"history": "5.3.0",
|
"history": "5.3.0",
|
||||||
"husky": "9.1.7",
|
"husky": "9.1.7",
|
||||||
"less": "4.4.1",
|
"less": "4.4.1",
|
||||||
"lint-staged": "15.5.2",
|
"lint-staged": "16.1.5",
|
||||||
"mocha": "10.8.2",
|
"mocha": "11.7.1",
|
||||||
"nodemon": "^3.1.10",
|
"nodemon": "^3.1.10",
|
||||||
"prettier": "3.6.2",
|
"prettier": "3.6.2",
|
||||||
"redux-logger": "3.0.6"
|
"redux-logger": "3.0.6"
|
||||||
|
|||||||
@@ -9,7 +9,6 @@ import { demoMode } from './models/demoMode.js';
|
|||||||
import { init } from '@rematch/core';
|
import { init } from '@rematch/core';
|
||||||
const middleware = [];
|
const middleware = [];
|
||||||
if (process.env.NODE_ENV === 'development') {
|
if (process.env.NODE_ENV === 'development') {
|
||||||
// eslint-disable-line no-redeclare
|
|
||||||
middleware.push(createLogger({ duration: false, collapsed: (getState, action, logEntry) => !logEntry.error }));
|
middleware.push(createLogger({ duration: false, collapsed: (getState, action, logEntry) => !logEntry.error }));
|
||||||
}
|
}
|
||||||
const store = init({
|
const store = init({
|
||||||
|
|||||||
Reference in New Issue
Block a user