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/package.json CHANGED
@@ -98,6 +98,6 @@
98
98
  "release": "standard-version"
99
99
  },
100
100
  "type": "module",
101
- "version": "0.0.98",
101
+ "version": "0.0.99",
102
102
  "author": ""
103
103
  }
@@ -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 infiniteScroll.paginationNewTable(self, filteredRows)
13
+ return this.paginationNewTable(self, filteredRows)
17
14
  } else {
18
15
  self.filteredRows = rows
19
- return infiniteScroll.paginationNewTable(self, rows)
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
- paginationNewTable (self: { pageLength: number; }, rows: object []): object [] {
24
- return rows.slice(0, self.$refs.table.pageLength)
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
- infiniteScroll.handleInfiniteScrollNewTable(this)
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
- infiniteScroll.handleInfiniteScrollNewTable(this)
556
+ this.$refs.table.handleInfiniteScrollTableCompositionAPi()
558
557
  }, 500)
559
558
  }
560
559
  }