mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 14:10:14 -05:00
206 lines
4.5 KiB
JavaScript
206 lines
4.5 KiB
JavaScript
/*
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
|
* http://paperjs.org/
|
|
*
|
|
* Copyright (c) 2011 - 2014, Juerg Lehni & Jonathan Puckey
|
|
* http://scratchdisk.com/ & http://jonathanpuckey.com/
|
|
*
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
*
|
|
* All rights reserved.
|
|
*/
|
|
|
|
module('Getting and Matching Items');
|
|
|
|
test('Item#getItems()', function() {
|
|
var group = new Group([new Path({ selected: true }), new Raster()]);
|
|
equals(function() {
|
|
return group.getItems({
|
|
type: 'path'
|
|
}).length;
|
|
}, 1);
|
|
|
|
equals(function() {
|
|
return group.getItems({
|
|
selected: true
|
|
}).length;
|
|
}, 1);
|
|
});
|
|
|
|
test('Item#matches()', function() {
|
|
var path = new Path();
|
|
equals(function() {
|
|
return path.matches({
|
|
visible: false
|
|
});
|
|
}, false);
|
|
|
|
equals(function() {
|
|
return path.matches({
|
|
visible: true
|
|
});
|
|
}, true);
|
|
});
|
|
|
|
test('Project#getItems()', function() {
|
|
var layer = new Layer();
|
|
|
|
var matches = paper.project.getItems({
|
|
class: Layer
|
|
});
|
|
equals(function() {
|
|
return matches.length == 1 && matches[0] == layer;
|
|
}, true);
|
|
|
|
var matches = paper.project.getItems({
|
|
class: Item
|
|
});
|
|
equals(function() {
|
|
return matches.length == 1 && matches[0] == layer;
|
|
}, true);
|
|
|
|
var path = new Path();
|
|
var matches = paper.project.getItems({
|
|
class: Path
|
|
});
|
|
equals(function() {
|
|
return matches.length == 1 && matches[0] == path;
|
|
}, true);
|
|
|
|
var group = new Group();
|
|
var matches = paper.project.getItems({
|
|
className: 'Group'
|
|
});
|
|
equals(function() {
|
|
return matches.length == 1 && matches[0] === group
|
|
}, true);
|
|
|
|
var matches = paper.project.getItems({
|
|
type: 'group'
|
|
});
|
|
equals(function() {
|
|
return matches.length == 1 && matches[0] === group
|
|
}, true);
|
|
|
|
var raster = new Raster();
|
|
var matches = paper.project.getItems({
|
|
class: Raster
|
|
});
|
|
equals(function() {
|
|
return matches.length == 1 && matches[0] === raster
|
|
}, true);
|
|
|
|
equals(function() {
|
|
return paper.project.getItems({
|
|
selected: true
|
|
}).length;
|
|
}, 0);
|
|
|
|
raster.selected = true;
|
|
equals(function() {
|
|
return paper.project.getItems({
|
|
selected: true
|
|
}).length;
|
|
}, 2);
|
|
|
|
raster.selected = true;
|
|
equals(function() {
|
|
return paper.project.getItems({
|
|
selected: true,
|
|
class: Raster
|
|
}).length;
|
|
}, 1);
|
|
});
|
|
|
|
test('Project#getItems() with compare function', function() {
|
|
var firstPath = new Path();
|
|
var path = new Path({
|
|
opacity: 0.5
|
|
});
|
|
|
|
var items = paper.project.getItems({
|
|
opacity: function(value) {
|
|
return value < 1
|
|
}
|
|
});
|
|
equals(function() {
|
|
return items.length == 1 && items[0] == path;
|
|
}, true);
|
|
});
|
|
|
|
test('Project#getItems() with specific property value', function() {
|
|
var path = new Path();
|
|
var decoyPath = new Path({
|
|
opacity: 0.5
|
|
});
|
|
|
|
var items = paper.project.getItems({
|
|
opacity: 1,
|
|
type: 'path'
|
|
});
|
|
equals(function() {
|
|
return items.length == 1 && items[0] == path;
|
|
}, true);
|
|
});
|
|
|
|
test('Project#getItems() with color', function() {
|
|
var path = new Path({
|
|
fillColor: 'red'
|
|
});
|
|
|
|
var decoyPath = new Path({
|
|
fillColor: 'black'
|
|
});
|
|
|
|
var items = paper.project.getItems({
|
|
fillColor: 'red',
|
|
type: 'path'
|
|
});
|
|
equals(function() {
|
|
return items.length == 1 && items[0] == path;
|
|
}, true);
|
|
});
|
|
|
|
test('Project#getItems() with regex function', function() {
|
|
var decoyPath = new Path({
|
|
name: 'stop'
|
|
});
|
|
|
|
var decoyPath2 = new Path({
|
|
name: 'pause'
|
|
});
|
|
|
|
var path = new Path({
|
|
name: 'starting'
|
|
});
|
|
|
|
var items = paper.project.getItems({
|
|
name: /^start/g
|
|
});
|
|
equals(function() {
|
|
return items.length == 1 && items[0] == path;
|
|
}, true);
|
|
|
|
equals(function() {
|
|
var items = paper.project.getItems({
|
|
name: /^st/g
|
|
});
|
|
return items.length == 2;
|
|
}, true);
|
|
});
|
|
|
|
test('Project#getItems() empty: true', function() {
|
|
var layer = new Layer();
|
|
var empty1 = new Path();
|
|
var empty2 = new Path();
|
|
|
|
equals(function() {
|
|
return layer.children.length;
|
|
}, 2);
|
|
|
|
equals(function() {
|
|
return paper.project.getItems({
|
|
empty: true
|
|
}).length;
|
|
}, 2);
|
|
});
|