以下に示すように、フィルタープラグインを備えた拡張グリッドがあります。
<!DOCTYPE html>
<html >
<head>
<style type="text/css">@import "./dojo/resources/dojo.css";
@import "./dojox/grid/enhanced/resources/claro/EnhancedGrid.css";
@import "./dojox/grid/enhanced/resources/EnhancedGrid_rtl.css";
/*Grid need a explicit width/height by default*/
#grid {
width: 45em;
height: 20em;
}</style>
<script data-dojo-config="async: true" src='./dojo/dojo.js'></script>
<script data-dojo-config="async: true" src='./dojo/mydojo.js'></script>
<script>
var dojoConfig = {
baseUrl: "./",
tlmSiblingOfDojo: false,
packages: [
{ name: "dojo", location: "dojo" },
{ name: "dijit", location: "dijit" },
{ name: "dojox", location: "dojox" }
]
};
require(["dojox/grid/EnhancedGrid","dojo/data/ItemFileWriteStore",
"dojox/grid/enhanced/plugins/Filter"],
function(EnhancedGrid,ItemFileWriteStore,Filter){
/*set up data store*/
var data = {
identifier: 'id',
items: []
};
var data_list = [
{ col1: "normal", col2: false,
col3: 'But are not followed by two hexadecimal', col4: 29.91},
{ col1: "important", col2: false,
col3: 'Because a % sign always indicates', col4: 9.33},
{ col1: "important", col2: false,
col3: 'Signs can be selectively', col4: 19.34}
];
var rows = 60;
for(var i=0, l=data_list.length; i<rows; i++){
data.items.push(dojo.mixin({ id: i+1 }, data_list[i%l]));
}
var store = ItemFileWriteStore({data: data});
/*set up layout*/
var layout = [[
{'name': 'Column 1', 'field': 'id'},
{'name': 'Column 2', 'field': 'col2'},
{'name': 'Column 3', 'field': 'col3', 'width': '230px'},
{'name': 'Column 4', 'field': 'col4', 'width': '230px'}
]];
/*create a new grid:*/
var grid = EnhancedGrid({
id: 'grid',
store: store,
structure: layout,
rowSelector: '20px',
plugins: {
filter: {
closeFilterbarButton: true,
ruleCount: 5,
itemsName: "songs"
}
}
}, "gridDiv");
/*append the new grid to the div*/
// dojo.byId("gridDiv").appendChild(grid.domNode);
/*Call startup() to render the grid*/
grid.startup();
//alert("ee");
//grid.placeAt("gridDiv");
});
</script>
</head>
<body class="claro">
<div id="gridDiv"></div>
</body>
</html>
上記の HTML を呼び出すと、Filter プラグインに関連する多数の HTML ファイルがダウンロードされていることがわかります。
/dojox/grid/enhanced/templates/FilterBar.html
/dojox/grid/enhanced/templates/FilterDefPane.html
/dojox/grid/enhanced/templates/CriteriaBox.html
/dojox/grid/enhanced/templates/FilterBoolValueBox.html
これらのファイルを EnhancedGrid の Javascript の一部にしたいと考えています。これまでのところ、次の解決策を見つけました。
http://grokbase.com/t/dojo/dojo-interest/11bs5jf64d/custom-build-include-css-and-html-files
しかし、上記のリンクで Kallenboone によるコードの使用方法を取得できません。
誰か助けてくれませんか。