fix eslint.

This commit is contained in:
fiatjaf 2021-12-13 12:59:42 -03:00
parent 86d49ffbec
commit 55c04c05f4
11 changed files with 152 additions and 58 deletions

View File

@ -1,13 +1,11 @@
module.exports = {
// https://eslint.org/docs/user-guide/configuring#configuration-cascading-and-hierarchy
// This option interrupts the configuration hierarchy at this file
// Remove this if you have an higher level ESLint config file (it usually happens into a monorepos)
root: true,
parserOptions: {
parser: '@babel/eslint-parser',
ecmaVersion: 2018, // Allows for the parsing of modern ECMAScript features
sourceType: 'module' // Allows for the use of imports
ecmaVersion: 2018,
sourceType: 'module',
requireConfigFile: false
},
env: {
@ -16,34 +14,16 @@ module.exports = {
// Rules order is important, please avoid shuffling them
extends: [
// Base ESLint recommended rules
// 'eslint:recommended',
// Uncomment any of the lines below to choose desired strictness,
// but leave only one uncommented!
// See https://eslint.vuejs.org/rules/#available-rules
'eslint:recommended',
'plugin:vue/vue3-essential', // Priority A: Essential (Error Prevention)
// 'plugin:vue/vue3-strongly-recommended', // Priority B: Strongly Recommended (Improving Readability)
// 'plugin:vue/vue3-recommended', // Priority C: Recommended (Minimizing Arbitrary Choices and Cognitive Overhead)
// https://github.com/prettier/eslint-config-prettier#installation
// usage with Prettier, provided by 'eslint-config-prettier'.
'plugin:vue/vue3-strongly-recommended', // Priority B: Strongly Recommended (Improving Readability)
'plugin:vue/vue3-recommended', // Priority C: Recommended (Minimizing Arbitrary Choices and Cognitive Overhead)
'prettier'
],
plugins: [
// https://eslint.vuejs.org/user-guide/#why-doesn-t-it-work-on-vue-file
// required to lint *.vue files
'vue',
// https://github.com/typescript-eslint/typescript-eslint/issues/389#issuecomment-509292674
// Prettier has not been included as plugin to avoid performance impact
// add it as an extension for your IDE
],
plugins: ['vue'],
globals: {
ga: 'readonly', // Google Analytics
cordova: 'readonly',
__statics: 'readonly',
__QUASAR_SSR__: 'readonly',
@ -55,12 +35,126 @@ module.exports = {
chrome: 'readonly'
},
// add your custom rules here
rules: {
'prefer-promise-reject-errors': 'off',
// allow debugger during development only
'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off'
'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
// custom
'vue/no-v-html': 0,
'accessor-pairs': 2,
'arrow-spacing': [2, {before: true, after: true}],
'block-spacing': [2, 'always'],
'brace-style': [2, '1tbs', {allowSingleLine: true}],
'comma-dangle': 0,
'comma-spacing': [2, {before: false, after: true}],
'comma-style': [2, 'last'],
'constructor-super': 2,
curly: [0, 'multi-line'],
'dot-location': [2, 'property'],
'eol-last': 2,
eqeqeq: [2, 'allow-null'],
'generator-star-spacing': [2, {before: true, after: true}],
'handle-callback-err': [2, '^(err|error)$'],
indent: 0,
'jsx-quotes': [2, 'prefer-double'],
'key-spacing': [2, {beforeColon: false, afterColon: true}],
'keyword-spacing': [2, {before: true, after: true}],
'new-cap': 0,
'new-parens': 0,
'no-array-constructor': 2,
'no-caller': 2,
'no-class-assign': 2,
'no-cond-assign': 2,
'no-const-assign': 2,
'no-control-regex': 0,
'no-debugger': 0,
'no-delete-var': 2,
'no-dupe-args': 2,
'no-dupe-class-members': 2,
'no-dupe-keys': 2,
'no-duplicate-case': 2,
'no-empty-character-class': 2,
'no-empty-pattern': 2,
'no-eval': 0,
'no-ex-assign': 2,
'no-extend-native': 2,
'no-extra-bind': 2,
'no-extra-boolean-cast': 2,
'no-extra-parens': [2, 'functions'],
'no-fallthrough': 2,
'no-floating-decimal': 2,
'no-func-assign': 2,
'no-implied-eval': 2,
'no-inner-declarations': [0, 'functions'],
'no-invalid-regexp': 2,
'no-irregular-whitespace': 2,
'no-iterator': 2,
'no-label-var': 2,
'no-labels': [2, {allowLoop: false, allowSwitch: false}],
'no-lone-blocks': 2,
'no-mixed-spaces-and-tabs': 2,
'no-multi-spaces': 2,
'no-multi-str': 2,
'no-multiple-empty-lines': [2, {max: 2}],
'no-native-reassign': 2,
'no-negated-in-lhs': 2,
'no-new': 0,
'no-new-func': 2,
'no-new-object': 2,
'no-new-require': 2,
'no-new-symbol': 2,
'no-new-wrappers': 2,
'no-obj-calls': 2,
'no-octal': 2,
'no-octal-escape': 2,
'no-path-concat': 0,
'no-proto': 2,
'no-redeclare': 2,
'no-regex-spaces': 2,
'no-return-assign': 0,
'no-self-assign': 2,
'no-self-compare': 2,
'no-sequences': 2,
'no-shadow-restricted-names': 2,
'no-spaced-func': 2,
'no-sparse-arrays': 2,
'no-this-before-super': 2,
'no-throw-literal': 2,
'no-trailing-spaces': 2,
'no-undef': 2,
'no-undef-init': 2,
'no-unexpected-multiline': 2,
'no-unneeded-ternary': [2, {defaultAssignment: false}],
'no-unreachable': 2,
'no-unused-vars': [
2,
{vars: 'local', args: 'none', varsIgnorePattern: '^_'}
],
'no-useless-call': 2,
'no-useless-constructor': 2,
'no-with': 2,
'one-var': [0, {initialized: 'never'}],
'operator-linebreak': [
2,
'after',
{overrides: {'?': 'before', ':': 'before'}}
],
'padded-blocks': [2, 'never'],
quotes: [2, 'single', {avoidEscape: true, allowTemplateLiterals: true}],
semi: [2, 'never'],
'semi-spacing': [2, {before: false, after: true}],
'space-before-blocks': [2, 'always'],
'space-before-function-paren': 0,
'space-in-parens': [2, 'never'],
'space-infix-ops': 2,
'space-unary-ops': [2, {words: true, nonwords: false}],
'spaced-comment': 0,
'template-curly-spacing': [2, 'never'],
'use-isnan': 2,
'valid-typeof': 2,
'wrap-iife': [2, 'any'],
'yield-star-spacing': [2, 'both'],
yoda: [0]
}
}

View File

@ -6,8 +6,7 @@
"author": "fiatjaf <fiatjaf@gmail.com>",
"private": true,
"scripts": {
"lint": "eslint --ext .js,.vue ./",
"test": "echo \"No test specified\" && exit 0"
"lint": "eslint --ext .js,.vue ./"
},
"dependencies": {
"@quasar/extras": "^1.0.0",

View File

@ -34,7 +34,7 @@ import helpersMixin from '../utils/mixin'
export default {
mixins: [helpersMixin],
props: ['event'],
props: {event: {type: Object, required: true}},
data() {
return {
dialogReply: false

View File

@ -2,9 +2,9 @@
<q-card class="no-shadow p-8">
<q-card-section>
<q-form @submit="sendPost">
<q-input dense v-model="text" label="Say something" maxlength="280">
<q-input v-model="text" dense label="Say something" maxlength="280">
<template #before>
<q-btn round @click="toProfile($store.state.keys.pub)" class="mr-3">
<q-btn round class="mr-3" @click="toProfile($store.state.keys.pub)">
<q-avatar size="42px">
<img :src="$store.getters.avatar($store.state.keys.pub)" />
</q-avatar>
@ -13,12 +13,12 @@
</q-input>
<div class="flex justify-end mt-3">
<q-btn
v-close-popup
label="Publish"
rounded
unelevated
type="submit"
color="primary"
v-close-popup
/>
</div>
</q-form>

View File

@ -57,7 +57,10 @@ import helpersMixin from '../utils/mixin'
export default {
mixins: [helpersMixin],
props: ['event', 'dialog'],
props: {
event: {type: Object, required: true},
dialog: {type: Object, default: null}
},
data() {
return {
text: ''

View File

@ -1,3 +1,5 @@
/* global emit */
import PouchDB from 'pouchdb-core'
import PouchDBAdapterIDB from 'pouchdb-adapter-idb'
import PouchDBMapReduce from 'pouchdb-mapreduce'
@ -73,7 +75,7 @@ export async function dbGetHomeFeedNotes(
return result.rows.map(r => r.doc)
}
export async function dbGetMentions(ourPubKey, limit = 20, offset = 0) {
export async function dbGetMentions(ourPubKey, limit = 20, skip = 0) {
let result = await db.query('main/mentions', {
include_docs: true,
descending: true,
@ -85,7 +87,7 @@ export async function dbGetMentions(ourPubKey, limit = 20, offset = 0) {
return result.rows.map(r => r.doc)
}
export async function dbGetMessages(peerPubKey, limit = 50, offset = 0) {
export async function dbGetMessages(peerPubKey, limit = 50, skip = 0) {
let result = await db.query('main/messages', {
include_docs: true,
descending: true,
@ -105,16 +107,14 @@ export async function dbGetProfile(pubkey) {
switch (result.rows.length) {
case 0:
return null
break
case 1:
return result.rows[0].doc
break
default:
default: {
let sorted = result.rows.sort(
(a, b) => b.doc.created_at - a.doc.created_at
)
sorted.slice(1).forEach(row => db.remove(row.doc))
return sorted[0].doc
break
}
}
}

View File

@ -52,7 +52,7 @@
<q-form
class="q-gutter-md"
@submit="submitMessage"
@reset="this.text = ''"
@reset="text = ''"
>
<div class="row">
<div class="col-8">
@ -126,7 +126,6 @@
</template>
<script>
import {LocalStorage} from 'quasar'
import helpersMixin from '../utils/mixin'
export default {

View File

@ -100,10 +100,6 @@ export default {
}
},
mounted() {
this.$store.dispatch('useProfile')
},
watch: {
'$route.params.pubkey'() {
this.events = []
@ -146,6 +142,10 @@ export default {
}
},
mounted() {
this.$store.dispatch('useProfile')
},
beforeUnmount() {
this.sub.unsub()
},

View File

@ -92,24 +92,24 @@
<q-card-section>
<p>Seed Words:</p>
<q-input
v-model="$store.state.keys.mnemonic"
class="mb-2"
readonly
v-model="$store.state.keys.mnemonic"
filled
/>
<p>Private Key:</p>
<q-input
v-model="$store.state.keys.priv"
class="mb-2"
readonly
v-model="$store.state.keys.priv"
filled
/>
<p>Public Key:</p>
<q-input readonly v-model="$store.state.keys.pub" filled> </q-input>
<q-input v-model="$store.state.keys.pub" readonly filled> </q-input>
</q-card-section>
<q-card-actions align="right" class="text-primary">
<q-btn flat label="Close" v-close-popup />
<q-btn v-close-popup flat label="Close" />
</q-card-actions>
</q-card>
</q-dialog>
@ -122,7 +122,7 @@
</q-card-section>
<q-card-actions align="right" class="text-primary">
<q-btn flat label="Cancel" v-close-popup />
<q-btn v-close-popup flat label="Cancel" />
<q-btn flat label="Yes, delete storage" @click="hardReset" />
</q-card-actions>
</q-card>

View File

@ -1,5 +1,3 @@
import {Buffer} from 'buffer'
import {LocalStorage} from 'quasar'
import {getPublicKey} from 'nostr-tools'
import {
generateSeedWords,

View File

@ -1,3 +1,4 @@
// eslint-disable-next-line
module.exports = {
content: ['./src/**/*.{vue,html}'],
theme: {