table-empty-mixin.js
2.65 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
'use strict';
Object.defineProperty(exports, "__esModule", {
            value: true
});
var _utils = require('../../src/utils/utils.js');
var _utils2 = _interopRequireDefault(_utils);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
            data: function data() {
                        return {
                                    isTableEmpty: false,
                                    tableEmptyHeight: 0
                        };
            },
            methods: {
                        tableEmpty: function tableEmpty() {
                                    var _this = this;
                                    var tableData = this.internalTableData,
                                        tableEmptyHeight = 0;
                                    if (Array.isArray(tableData) && tableData.length > 0) {
                                                this.isTableEmpty = false;
                                                return false;
                                    }
                                    this.isTableEmpty = true;
                                    tableEmptyHeight = this.getTotalColumnsHeight() + this.errorContentHeight;
                                    this.tableEmptyHeight = tableEmptyHeight;
                                    this.$nextTick(function (x) {
                                                _this.tableEmptyScroll();
                                    });
                        },
                        tableEmptyScrollEvent: function tableEmptyScrollEvent(e) {
                                    var headerEle = this.$el.querySelector('.v-table-rightview .v-table-header'),
                                        tableEmptyEle = this.$el.querySelector('.v-table-empty .v-table-empty-scroll');
                                    if (tableEmptyEle) {
                                                headerEle.scrollLeft = tableEmptyEle.scrollLeft;
                                    }
                        },
                        tableEmptyScroll: function tableEmptyScroll() {
                                    var tableEmptyEle = this.$el.querySelector('.v-table-empty .v-table-empty-scroll');
                                    _utils2.default.bind(tableEmptyEle, 'scroll', this.tableEmptyScrollEvent);
                        }
            },
            beforeDestroy: function beforeDestroy() {
                        var tableEmptyEle = this.$el.querySelector('.v-table-empty .v-table-empty-scroll');
                        _utils2.default.unbind(tableEmptyEle, 'scroll', this.tableEmptyScrollEvent);
            }
};