quasar-factory-lib 0.0.98 → 0.0.99
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.
- package/dist/components/Table/Table.vue.d.ts +1 -0
- package/dist/components/Table/utils/filterMethod.d.ts +3 -0
- package/dist/components/Table/utils/infiniteScroll.d.ts +1 -3
- package/dist/layouts/PdaLayout.vue.d.ts +1 -0
- package/dist/pages/TablePage.vue.d.ts +1 -0
- package/dist/quasar-factory-lib.js +1527 -1505
- package/dist/quasar-factory-lib.umd.cjs +12 -12
- package/package.json +1 -1
- package/src/components/Table/Table.vue +19 -0
- package/src/components/Table/utils/filterMethod.ts +5 -6
- package/src/components/Table/utils/infiniteScroll.ts +22 -2
- package/src/layouts/PdaLayout.vue +2 -3
package/package.json
CHANGED
|
@@ -515,6 +515,25 @@ export default defineComponent({
|
|
|
515
515
|
acc[column.name] = ''
|
|
516
516
|
return acc
|
|
517
517
|
}, {} as { [key: string]: string })
|
|
518
|
+
},
|
|
519
|
+
handleInfiniteScrollTableCompositionAPi () {
|
|
520
|
+
this.$nextTick(() => {
|
|
521
|
+
const elemClass = this.smallDevice ? 'q-table__grid-content' : 'q-table__middle scroll'
|
|
522
|
+
const tableType = this.smallDevice ? 'Grid' : 'Table'
|
|
523
|
+
const qtableScrollElem = document.getElementsByClassName(elemClass) as HTMLCollectionOf<HTMLElement>
|
|
524
|
+
const elementToScroll =
|
|
525
|
+
qtableScrollElem.length > 0 ? qtableScrollElem[0] : window
|
|
526
|
+
const fnAddScroll = (event: Event) => {
|
|
527
|
+
const { scrollHeight, scrollTop, clientHeight } = event.target as HTMLElement
|
|
528
|
+
if (Math.abs(scrollHeight - clientHeight - scrollTop) < 1) {
|
|
529
|
+
console.log(`[${tableType}] You are at the bottom!`, this.totalPage)
|
|
530
|
+
this.totalPage++
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
window.removeEventListener('scroll', fnAddScroll)
|
|
534
|
+
elementToScroll.removeEventListener('scroll', fnAddScroll)
|
|
535
|
+
elementToScroll.addEventListener('scroll', fnAddScroll)
|
|
536
|
+
})
|
|
518
537
|
}
|
|
519
538
|
}
|
|
520
539
|
})
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
/* eslint-disable */
|
|
2
|
-
|
|
3
|
-
import infiniteScroll from './infiniteScroll'
|
|
4
1
|
const filterMethod = {
|
|
5
2
|
filter (self: { filteredRows: object [] | [] }, rows: string | [], terms: { search: string }) {
|
|
6
3
|
console.log(rows)
|
|
@@ -13,13 +10,15 @@ const filterMethod = {
|
|
|
13
10
|
}
|
|
14
11
|
}
|
|
15
12
|
self.filteredRows = filteredRows
|
|
16
|
-
return
|
|
13
|
+
return this.paginationNewTable(self, filteredRows)
|
|
17
14
|
} else {
|
|
18
15
|
self.filteredRows = rows
|
|
19
|
-
return
|
|
16
|
+
return this.paginationNewTable(self, rows)
|
|
20
17
|
}
|
|
21
18
|
},
|
|
22
|
-
|
|
19
|
+
paginationNewTable (self: { pageLength: number; }, rows: object []): object [] {
|
|
20
|
+
return rows.slice(0, self.$refs.table.pageLength)
|
|
21
|
+
},
|
|
23
22
|
containsSearchTermInRow (row: object, lowerSearch: string): boolean {
|
|
24
23
|
if (lowerSearch !== '') {
|
|
25
24
|
const values = Object.values(row)
|
|
@@ -20,9 +20,29 @@ const infiniteScroll = {
|
|
|
20
20
|
elementToScroll.addEventListener('scroll', fnAddScroll)
|
|
21
21
|
})
|
|
22
22
|
},
|
|
23
|
-
|
|
24
|
-
|
|
23
|
+
handleInfiniteScrollNewTableCompositionAPi (nextTick, smallDevice, totalPage) {
|
|
24
|
+
nextTick(() => {
|
|
25
|
+
const elemClass = smallDevice ? 'q-table__grid-content' : 'q-table__middle scroll'
|
|
26
|
+
const tableType = smallDevice ? 'Grid' : 'Table'
|
|
27
|
+
const qtableScrollElem = document.getElementsByClassName(elemClass) as HTMLCollectionOf<HTMLElement>
|
|
28
|
+
const elementToScroll =
|
|
29
|
+
qtableScrollElem.length > 0 ? qtableScrollElem[0] : window
|
|
30
|
+
const fnAddScroll = (event: Event) => {
|
|
31
|
+
console.log(totalPage, 'totalPage')
|
|
32
|
+
const { scrollHeight, scrollTop, clientHeight } = event.target as HTMLElement
|
|
33
|
+
if (Math.abs(scrollHeight - clientHeight - scrollTop) < 1) {
|
|
34
|
+
console.log(`[${tableType}] You are at the bottom!`, totalPage)
|
|
35
|
+
totalPage++
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
window.removeEventListener('scroll', fnAddScroll)
|
|
39
|
+
elementToScroll.removeEventListener('scroll', fnAddScroll)
|
|
40
|
+
elementToScroll.addEventListener('scroll', fnAddScroll)
|
|
41
|
+
})
|
|
25
42
|
},
|
|
43
|
+
/* paginationNewTable (self: { pageLength: number; }, rows: object []): object [] {
|
|
44
|
+
return rows.slice(0, self.$refs.table.pageLength)
|
|
45
|
+
}, */
|
|
26
46
|
handleInfiniteScrollModal (self: { $nextTick: (arg0: () => void) => void; totalPageModal: number; smallDevice: boolean }, tableID: string): void {
|
|
27
47
|
console.log('handleInfiniteScrollModal')
|
|
28
48
|
self.$nextTick(() => {
|
|
@@ -84,7 +84,6 @@ import NavBarSkeleton from '../components/NavBarSkeleton/NavBarSkeleton.vue'
|
|
|
84
84
|
import TableRowsCounter from'../components/TableRowsCounter/TableRowsCounter.vue'
|
|
85
85
|
import AlertLabelsWithError from '../components/AlertLabelsWithError/AlertLabelsWithError.vue'
|
|
86
86
|
import setTableHeight from '../components/Table/utils/setTableHeight'
|
|
87
|
-
import infiniteScroll from '../components/Table/utils/infiniteScroll'
|
|
88
87
|
import { tableStore } from '../store/table.js'
|
|
89
88
|
export default {
|
|
90
89
|
components: {
|
|
@@ -547,14 +546,14 @@ export default {
|
|
|
547
546
|
'$q.screen.width' (): void {
|
|
548
547
|
setTimeout(() => {
|
|
549
548
|
this.tableStyle = setTableHeight.setTableHeight()
|
|
550
|
-
|
|
549
|
+
this.$refs.table.handleInfiniteScrollTableCompositionAPi()
|
|
551
550
|
}, 500)
|
|
552
551
|
},
|
|
553
552
|
showSkeleton (val: boolean) {
|
|
554
553
|
if (!val) {
|
|
555
554
|
setTimeout(() => {
|
|
556
555
|
this.tableStyle = setTableHeight.setTableHeight()
|
|
557
|
-
|
|
556
|
+
this.$refs.table.handleInfiniteScrollTableCompositionAPi()
|
|
558
557
|
}, 500)
|
|
559
558
|
}
|
|
560
559
|
}
|