annotate default/node_modules/tablesaw/src/tables.stack.js @ 0:1d038bc9b3d2 default tip

Up:default
author Liny <dev@neowd.com>
date Sat, 31 May 2025 09:21:51 +0800
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
1 /*
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
2 * tablesaw: A set of plugins for responsive tables
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
3 * Stack: switches from column layout to rows with inline labels
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
4 * Copyright (c) 2013 Filament Group, Inc.
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
5 * MIT License
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
6 */
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
7
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
8 (function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
9 var classes = {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
10 stackTable: "tablesaw-stack",
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
11 cellLabels: "tablesaw-cell-label",
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
12 cellContentLabels: "tablesaw-cell-content"
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
13 };
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
14
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
15 var data = {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
16 key: "tablesaw-stack"
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
17 };
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
18
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
19 var attrs = {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
20 labelless: "data-tablesaw-no-labels",
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
21 hideempty: "data-tablesaw-hide-empty"
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
22 };
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
23
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
24 var Stack = function(element, tablesaw) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
25 this.tablesaw = tablesaw;
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
26 this.$table = $(element);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
27
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
28 this.labelless = this.$table.is("[" + attrs.labelless + "]");
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
29 this.hideempty = this.$table.is("[" + attrs.hideempty + "]");
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
30
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
31 this.$table.data(data.key, this);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
32 };
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
33
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
34 Stack.prototype.init = function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
35 this.$table.addClass(classes.stackTable);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
36
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
37 if (this.labelless) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
38 return;
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
39 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
40
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
41 var self = this;
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
42
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
43 this.$table
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
44 .find("th, td")
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
45 .filter(function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
46 return !$(this).closest("thead").length;
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
47 })
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
48 .filter(function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
49 return (
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
50 !$(this)
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
51 .closest("tr")
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
52 .is("[" + attrs.labelless + "]") &&
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
53 (!self.hideempty || !!$(this).html())
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
54 );
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
55 })
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
56 .each(function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
57 var $newHeader = $(document.createElement("b")).addClass(classes.cellLabels);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
58 var $cell = $(this);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
59
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
60 $(self.tablesaw._findPrimaryHeadersForCell(this)).each(function(index) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
61 var $header = $(this.cloneNode(true));
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
62 // TODO decouple from sortable better
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
63 // Changed from .text() in https://github.com/filamentgroup/tablesaw/commit/b9c12a8f893ec192830ec3ba2d75f062642f935b
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
64 // to preserve structural html in headers, like <a>
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
65 var $sortableButton = $header.find(".tablesaw-sortable-btn");
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
66 $header.find(".tablesaw-sortable-arrow").remove();
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
67
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
68 // TODO decouple from checkall better
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
69 var $checkall = $header.find("[data-tablesaw-checkall]");
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
70 $checkall.closest("label").remove();
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
71 if ($checkall.length) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
72 $newHeader = $([]);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
73 return;
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
74 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
75
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
76 if (index > 0) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
77 $newHeader.append(document.createTextNode(", "));
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
78 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
79 $newHeader.append(
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
80 $sortableButton.length ? $sortableButton[0].childNodes : $header[0].childNodes
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
81 );
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
82 });
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
83
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
84 if ($newHeader.length && !$cell.find("." + classes.cellContentLabels).length) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
85 $cell.wrapInner("<span class='" + classes.cellContentLabels + "'></span>");
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
86 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
87
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
88 // Update if already exists.
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
89 var $label = $cell.find("." + classes.cellLabels);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
90 if (!$label.length) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
91 $cell.prepend($newHeader);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
92 } else {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
93 // only if changed
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
94 $label.replaceWith($newHeader);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
95 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
96 });
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
97 };
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
98
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
99 Stack.prototype.destroy = function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
100 this.$table.removeClass(classes.stackTable);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
101 this.$table.find("." + classes.cellLabels).remove();
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
102 this.$table.find("." + classes.cellContentLabels).each(function() {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
103 $(this).replaceWith(this.childNodes);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
104 });
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
105 };
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
106
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
107 // on tablecreate, init
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
108 $(document)
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
109 .on(Tablesaw.events.create, function(e, tablesaw) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
110 if (tablesaw.mode === "stack") {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
111 var table = new Stack(tablesaw.table, tablesaw);
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
112 table.init();
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
113 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
114 })
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
115 .on(Tablesaw.events.refresh, function(e, tablesaw) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
116 if (tablesaw.mode === "stack") {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
117 $(tablesaw.table)
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
118 .data(data.key)
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
119 .init();
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
120 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
121 })
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
122 .on(Tablesaw.events.destroy, function(e, tablesaw) {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
123 if (tablesaw.mode === "stack") {
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
124 $(tablesaw.table)
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
125 .data(data.key)
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
126 .destroy();
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
127 }
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
128 });
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
129
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
130 Tablesaw.Stack = Stack;
1d038bc9b3d2 Up:default
Liny <dev@neowd.com>
parents:
diff changeset
131 })();