quasar-factory-lib 0.0.98 → 0.1.0
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 +1535 -1505
- package/dist/quasar-factory-lib.umd.cjs +12 -12
- package/package.json +1 -1
- package/src/components/Table/Table.vue +29 -0
- package/src/components/Table/utils/filterMethod.ts +5 -6
- package/src/components/Table/utils/infiniteScroll.ts +22 -2
- package/src/layouts/PdaLayout.vue +11 -3
package/package.json
CHANGED
|
@@ -307,6 +307,16 @@ export default defineComponent({
|
|
|
307
307
|
} else {
|
|
308
308
|
this.dragAndDropDelay = 0
|
|
309
309
|
}
|
|
310
|
+
},
|
|
311
|
+
showSkeleton (val: boolean): void {
|
|
312
|
+
if (!val) {
|
|
313
|
+
this.handleInfiniteScrollTableCompositionAPi()
|
|
314
|
+
}
|
|
315
|
+
},
|
|
316
|
+
'$q.screen.width' (): void {
|
|
317
|
+
setTimeout(() => {
|
|
318
|
+
this.handleInfiniteScrollTableCompositionAPi()
|
|
319
|
+
}, 500)
|
|
310
320
|
}
|
|
311
321
|
},
|
|
312
322
|
mounted () {
|
|
@@ -515,6 +525,25 @@ export default defineComponent({
|
|
|
515
525
|
acc[column.name] = ''
|
|
516
526
|
return acc
|
|
517
527
|
}, {} as { [key: string]: string })
|
|
528
|
+
},
|
|
529
|
+
handleInfiniteScrollTableCompositionAPi () {
|
|
530
|
+
this.$nextTick(() => {
|
|
531
|
+
const elemClass = this.smallDevice ? 'q-table__grid-content' : 'q-table__middle scroll'
|
|
532
|
+
const tableType = this.smallDevice ? 'Grid' : 'Table'
|
|
533
|
+
const qtableScrollElem = document.getElementsByClassName(elemClass) as HTMLCollectionOf<HTMLElement>
|
|
534
|
+
const elementToScroll =
|
|
535
|
+
qtableScrollElem.length > 0 ? qtableScrollElem[0] : window
|
|
536
|
+
const fnAddScroll = (event: Event) => {
|
|
537
|
+
const { scrollHeight, scrollTop, clientHeight } = event.target as HTMLElement
|
|
538
|
+
if (Math.abs(scrollHeight - clientHeight - scrollTop) < 1) {
|
|
539
|
+
console.log(`[${tableType}] You are at the bottom!`, this.totalPage)
|
|
540
|
+
this.totalPage++
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
window.removeEventListener('scroll', fnAddScroll)
|
|
544
|
+
elementToScroll.removeEventListener('scroll', fnAddScroll)
|
|
545
|
+
elementToScroll.addEventListener('scroll', fnAddScroll)
|
|
546
|
+
})
|
|
518
547
|
}
|
|
519
548
|
}
|
|
520
549
|
})
|
|
@@ -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,7 @@ 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'
|
|
87
|
+
// import infiniteScroll from '../components/Table/utils/infiniteScroll'
|
|
88
88
|
import { tableStore } from '../store/table.js'
|
|
89
89
|
export default {
|
|
90
90
|
components: {
|
|
@@ -101,6 +101,14 @@ export default {
|
|
|
101
101
|
store: tableStore(),
|
|
102
102
|
tableStyle: '',
|
|
103
103
|
columns: [
|
|
104
|
+
{
|
|
105
|
+
name: 'drag-and-drop',
|
|
106
|
+
required: true,
|
|
107
|
+
label: 'Drag and drop',
|
|
108
|
+
align: 'left',
|
|
109
|
+
sortable: true,
|
|
110
|
+
type: 'string',
|
|
111
|
+
},
|
|
104
112
|
{
|
|
105
113
|
name: 'name',
|
|
106
114
|
required: true,
|
|
@@ -547,14 +555,14 @@ export default {
|
|
|
547
555
|
'$q.screen.width' (): void {
|
|
548
556
|
setTimeout(() => {
|
|
549
557
|
this.tableStyle = setTableHeight.setTableHeight()
|
|
550
|
-
infiniteScroll.handleInfiniteScrollNewTable(this)
|
|
558
|
+
// infiniteScroll.handleInfiniteScrollNewTable(this)
|
|
551
559
|
}, 500)
|
|
552
560
|
},
|
|
553
561
|
showSkeleton (val: boolean) {
|
|
554
562
|
if (!val) {
|
|
555
563
|
setTimeout(() => {
|
|
556
564
|
this.tableStyle = setTableHeight.setTableHeight()
|
|
557
|
-
infiniteScroll.handleInfiniteScrollNewTable(this)
|
|
565
|
+
// infiniteScroll.handleInfiniteScrollNewTable(this)
|
|
558
566
|
}, 500)
|
|
559
567
|
}
|
|
560
568
|
}
|