Skip to content

Commit

Permalink
fix bug: At.vue insertHtml 'suffix' is not defined !! also other esli…
Browse files Browse the repository at this point in the history
  • Loading branch information
fritx committed Aug 8, 2022
1 parent 4bc5c8a commit 4e46e5a
Show file tree
Hide file tree
Showing 7 changed files with 87 additions and 34 deletions.
33 changes: 33 additions & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
module.exports = {
root: true,
env: {},
extends: [
'plugin:vue/vue3-recommended',
'@vue/standard'
],
parserOptions: {
},
rules: {
'vue/multiline-html-element-content-newline': 'off',
'vue/first-attribute-linebreak': 'off',
'vue/max-attributes-per-line': 'off',
'vue/component-tags-order': 'off',
'vue/order-in-components': 'off',
'vue/html-self-closing': 'off',
'vue/attributes-order': 'off',
'vue/html-indent': 'off',
'space-before-function-paren': ['error', {
anonymous: 'always',
named: 'always',
asyncArrow: 'always'
}],
'no-irregular-whitespace': 'off',
'no-mixed-operators': 'off',
'no-unused-vars': 'off',
'prefer-const': 'off',
'comma-dangle': 'off',
'max-len': 'off',
'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off',
'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off'
}
}
6 changes: 6 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@
"author": "Fritz Lin <[email protected]>",
"repository": "https://github.com/fritx/vue-at",
"scripts": {
"lint:fix": "vue-cli-service lint",
"lint": "vue-cli-service lint --no-fix",
"dev": "vue-cli-service serve",
"demo": "vue-cli-service build",
"build:at": "vue-cli-service build ./src/At.vue --target lib --name vue-at",
Expand All @@ -21,9 +23,13 @@
},
"devDependencies": {
"@babel/core": "^7.18.9",
"@vue/cli-plugin-eslint": "^5.0.8",
"@vue/cli-service": "^5.0.8",
"@vue/compat": "^3.1.0",
"@vue/compiler-sfc": "^3.1.0",
"@vue/eslint-config-standard": "^8.0.1",
"eslint": "^8.21.0",
"eslint-plugin-vue": "^9.3.0",
"npm-run-all": "^4.1.5",
"rimraf": "^3.0.2",
"sass": "^1.53.0",
Expand Down
14 changes: 7 additions & 7 deletions src/App.vue
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
</template> -->

<!-- custom: with avatars -->
<template v-slot:item="s">
<template #item="s">
<img :src="s.item.avatar">
<span v-text="s.item.name"></span>
</template>
Expand All @@ -28,12 +28,12 @@
</at>

<at :members="members" name-key="name" v-model:value="html2">
<template v-slot:embeddedItem="s">
<template #embeddedItem="s">
<span><span class="tag"><img class="avatar" :src="s.current.avatar">{{ s.current.name }}</span></span>
</template>

<!-- custom: with avatars -->
<template v-slot:item="s">
<template #item="s">
<img :src="s.item.avatar">
<span v-text="s.item.name"></span>
</template>
Expand All @@ -45,7 +45,7 @@

<at-ta :members="members" name-key="name" v-model:value="text">
<!-- custom: with avatars -->
<template v-slot:item="s">
<template #item="s">
<img :src="s.item.avatar">
<span v-text="s.item.name"></span>
</template>
Expand Down Expand Up @@ -104,13 +104,13 @@ members = members.map((v, i) => {
export default {
components: { At, AtTa },
name: 'app',
name: 'App',
data () {
const data = {
members,
text: `
<<< Textarea >>>
Awesome Electron 
Awesome Electron
Useful resources for creating apps with Electron
Inspired by the awesome list thing. You might also like awesome-nodejs.
Example apps
Expand All @@ -119,7 +119,7 @@ Open Source
Atom - Code editor.
Nuclide - Unified IDE.
Playback - Video player.
Awesome Electron 
Awesome Electron
Useful resources for creating apps with Electron
Inspired by the awesome list thing. You might also like awesome-nodejs.
Example apps
Expand Down
31 changes: 16 additions & 15 deletions src/At.vue
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,9 @@ import {
import AtTemplate from './AtTemplate.vue'
export default {
name: 'At',
name: 'VueAt',
mixins: [AtTemplate],
emits: ['input', 'at', 'insert'],
props: {
value: {
type: String, // value not required
Expand Down Expand Up @@ -95,9 +96,9 @@ export default {
currentItem () {
if (this.atwho) {
return this.atwho.list[this.atwho.cur];
return this.atwho.list[this.atwho.cur]
}
return '';
return ''
},
style () {
Expand Down Expand Up @@ -180,8 +181,8 @@ export default {
if (range) {
// fixme: Very bad code from me
if (this.customsEmbedded && range.endOffset >= 1) {
let a = range.endContainer.childNodes[range.endOffset]
|| range.endContainer.childNodes[range.endOffset - 1]
let a = range.endContainer.childNodes[range.endOffset] ||
range.endContainer.childNodes[range.endOffset - 1]
if (!a || a.nodeType === Node.TEXT_NODE && !/^\s?$/.test(a.data)) {
return
} else if (a.nodeType === Node.TEXT_NODE) {
Expand Down Expand Up @@ -431,23 +432,23 @@ export default {
insertHtml (html, r) {
r.deleteContents()
const node = r.endContainer
var newElement = document.createElement('span')
let newElement = document.createElement('span')
// Seems `contentediable=false` should includes spaces,
// otherwise, caret can't be placed well across them
newElement.appendChild(document.createTextNode(' '))
newElement.appendChild(this.htmlToElement(html))
newElement.appendChild(document.createTextNode(' '))
newElement.setAttribute('data-at-embedded', '')
newElement.setAttribute("contenteditable", false)
newElement.setAttribute('contenteditable', false)
if (node.nodeType === Node.TEXT_NODE) {
const cut = r.endOffset
var secondPart = node.splitText(cut);
node.parentNode.insertBefore(newElement, secondPart);
let secondPart = node.splitText(cut)
node.parentNode.insertBefore(newElement, secondPart)
r.setEndBefore(secondPart)
} else {
const t = document.createTextNode(suffix)
const t = document.createTextNode(this.suffix)
r.insertNode(newElement)
r.setEndAfter(newElement)
r.insertNode(t)
Expand Down Expand Up @@ -488,17 +489,17 @@ export default {
this.insertHtml(html, r)
} else {
const t = itemName(curItem) + suffix
this.insertText(t, r);
this.insertText(t, r)
}
this.$emit('insert', curItem)
this.handleInput()
},
htmlToElement (html) {
var template = document.createElement('template');
html = html.trim(); // Never return a text node of whitespace as the result
template.innerHTML = html;
return template.content.firstChild;
const template = document.createElement('template')
html = html.trim() // Never return a text node of whitespace as the result
template.innerHTML = html
return template.content.firstChild
}
}
}
Expand Down
28 changes: 20 additions & 8 deletions src/AtTemplate.vue
Original file line number Diff line number Diff line change
@@ -1,39 +1,51 @@
<style lang="scss" src="./At.scss"></style>

<template>
<div ref="wrap"
<div
ref="wrap"
class="atwho-wrap"
@compositionstart="handleCompositionStart"
@compositionend="handleCompositionEnd"
@input="handleInput()"
@keydown.capture="handleKeyDown"
>
<div v-if="atwho"
<div
v-if="atwho"
class="atwho-panel"
:style="style"
>
<div class="atwho-inner">
<div class="atwho-view">
<ul class="atwho-ul">
<li v-for="(item, index) in atwho.list"
<li
v-for="(item, index) in atwho.list"
class="atwho-li"
:key="index"
:class="isCur(index) && 'atwho-cur'"
:data-index="index"
@mouseenter="handleItemHover"
@click="handleItemClick"
>
<slot name="item" :item="item">
<span v-text="itemName(item)"></span>
<slot
name="item"
:item="item"
>
<span v-text="itemName(item)" />
</slot>
</li>
</ul>
</div>
</div>
</div>
<span v-show="false" ref="embeddedItem">
<slot name="embeddedItem" :current="currentItem"></slot>
<span
v-show="false"
ref="embeddedItem"
>
<slot
name="embeddedItem"
:current="currentItem"
/>
</span>
<slot></slot>
<slot />
</div>
</template>
1 change: 1 addition & 0 deletions src/AtTextarea.vue
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import { getAtAndIndex } from './util'
export default {
extends: At,
name: 'AtTextarea',
emits: ['input', 'at', 'insert'],
computed: {
style () {
if (this.atwho) {
Expand Down
8 changes: 4 additions & 4 deletions src/util.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// bug report: https://github.com/vuejs/awesome-vue/pull/1028
// https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollIntoViewIfNeeded
export function scrollIntoView(el, scrollParent) {
export function scrollIntoView (el, scrollParent) {
if (el.scrollIntoViewIfNeeded) {
el.scrollIntoViewIfNeeded(false) // alignToCenter=false
} else {
Expand All @@ -14,21 +14,21 @@ export function scrollIntoView(el, scrollParent) {
}
}

export function applyRange(range) {
export function applyRange (range) {
const selection = window.getSelection()
if (selection) { // 容错
selection.removeAllRanges()
selection.addRange(range)
}
}
export function getRange() {
export function getRange () {
const selection = window.getSelection()
if (selection && selection.rangeCount > 0) {
return selection.getRangeAt(0)
}
}

export function getAtAndIndex(text, ats) {
export function getAtAndIndex (text, ats) {
return ats.map((at) => {
return { at, index: text.lastIndexOf(at) }
}).reduce((a, b) => {
Expand Down

0 comments on commit 4e46e5a

Please sign in to comment.