mirror of
https://github.com/styppo/hamstr.git
synced 2024-10-18 13:33:22 +00:00
fix eslint.
This commit is contained in:
parent
86d49ffbec
commit
55c04c05f4
158
.eslintrc.js
158
.eslintrc.js
@ -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]
|
||||
}
|
||||
}
|
||||
|
@ -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",
|
||||
|
@ -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
|
||||
|
@ -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>
|
||||
|
@ -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: ''
|
||||
|
12
src/db.js
12
src/db.js
@ -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
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -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 {
|
||||
|
@ -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()
|
||||
},
|
||||
|
@ -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>
|
||||
|
@ -1,5 +1,3 @@
|
||||
import {Buffer} from 'buffer'
|
||||
import {LocalStorage} from 'quasar'
|
||||
import {getPublicKey} from 'nostr-tools'
|
||||
import {
|
||||
generateSeedWords,
|
||||
|
@ -1,3 +1,4 @@
|
||||
// eslint-disable-next-line
|
||||
module.exports = {
|
||||
content: ['./src/**/*.{vue,html}'],
|
||||
theme: {
|
||||
|
Loading…
Reference in New Issue
Block a user