* * @copyright Copyright (c) 2015, ownCloud, Inc. * @license AGPL-3.0 * * This code is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License, version 3, * along with this program. If not, see * */ namespace Test; use OC\CapabilitiesManager; use OCP\AppFramework\QueryException; use OCP\Capabilities\ICapability; use OCP\Capabilities\IPublicCapability; use Psr\Log\LoggerInterface; class CapabilitiesManagerTest extends TestCase { /** @var CapabilitiesManager */ private $manager; /** @var LoggerInterface */ private $logger; protected function setUp(): void { parent::setUp(); $this->logger = $this->getMockBuilder(LoggerInterface::class)->getMock(); $this->manager = new CapabilitiesManager($this->logger); } /** * Test no capabilities */ public function testNoCapabilities() { $res = $this->manager->getCapabilities(); $this->assertEmpty($res); } /** * Test a valid capabilitie */ public function testValidCapability() { $this->manager->registerCapability(function () { return new SimpleCapability(); }); $res = $this->manager->getCapabilities(); $this->assertEquals(['foo' => 1], $res); } /** * Test a public capabilitie */ public function testPublicCapability() { $this->manager->registerCapability(function () { return new PublicSimpleCapability1(); }); $this->manager->registerCapability(function () { return new SimpleCapability2(); }); $this->manager->registerCapability(function () { return new SimpleCapability3(); }); $res = $this->manager->getCapabilities(true); $this->assertEquals(['foo' => 1], $res); } /** * Test that we need something that implents ICapability */ public function testNoICapability() { $this->expectException(\InvalidArgumentException::class); $this->expectExceptionMessage('The given Capability (Test\\NoCapability) does not implement the ICapability interface'); $this->manager->registerCapability(function () { return new NoCapability(); }); $res = $this->manager->getCapabilities(); $this->assertEquals([], $res); } /** * Test a bunch of merged Capabilities */ public function testMergedCapabilities() { $this->manager->registerCapability(function () { return new SimpleCapability(); }); $this->manager->registerCapability(function () { return new SimpleCapability2(); }); $this->manager->registerCapability(function () { return new SimpleCapability3(); }); $res = $this->manager->getCapabilities(); $expected = [ 'foo' => 1, 'bar' => [ 'x' => 1, 'y' => 2 ] ]; $this->assertEquals($expected, $res); } /** * Test deep identical capabilities */ public function testDeepIdenticalCapabilities() { $this->manager->registerCapability(function () { return new DeepCapability(); }); $this->manager->registerCapability(function () { return new DeepCapability(); }); $res = $this->manager->getCapabilities(); $expected = [ 'foo' => [ 'bar' => [ 'baz' => true ] ] ]; $this->assertEquals($expected, $res); } public function testInvalidCapability() { $this->manager->registerCapability(function () { throw new QueryException(); }); $this->logger->expects($this->once()) ->method('error'); $res = $this->manager->getCapabilities(); $this->assertEquals([], $res); } } class SimpleCapability implements ICapability { public function getCapabilities() { return [ 'foo' => 1 ]; } } class SimpleCapability2 implements ICapability { public function getCapabilities() { return [ 'bar' => ['x' => 1] ]; } } class SimpleCapability3 implements ICapability { public function getCapabilities() { return [ 'bar' => ['y' => 2] ]; } } class PublicSimpleCapability1 implements IPublicCapability { public function getCapabilities() { return [ 'foo' => 1 ]; } } class NoCapability { public function getCapabilities() { return [ 'baz' => 'z' ]; } } class DeepCapability implements ICapability { public function getCapabilities() { return [ 'foo' => [ 'bar' => [ 'baz' => true ] ] ]; } } ns-f50e11107c&id=9ef415042598ad978414f832b7bf52f20c67cce1'>root/ui/effect-puff.js
blob: ac3f90a64d242f315beac5df9bfd041c7cb53bee (plain)
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
/*!
 * jQuery UI Effects Puff @VERSION
 * http://jqueryui.com
 *
 * Copyright jQuery Foundation and other contributors
 * Released under the MIT license.
 * http://jquery.org/license
 */

//>>label: Puff Effect
//>>group: Effects
//>>description: Creates a puff effect by scaling the element up and hiding it at the same time.
//>>docs: http://api.jqueryui.com/puff-effect/
//>>demos: http://jqueryui.com/effect/

( function( factory ) {
	if ( typeof define === "function" && define.amd ) {

		// AMD. Register as an anonymous module.
		define( [
			"jquery",
			"./effect",
			"./effect-scale"
		], factory );
	} else {

		// Browser globals
		factory( jQuery );
	}
}( function( $ ) {

return $.effects.define( "puff", "hide", function( options, done ) {
	var newOptions = $.extend( true, {}, options, {
		fade: true,
		percent: parseInt( options.percent, 10 ) || 150
	} );

	$.effects.effect.scale.call( this, newOptions, done );
} );

} ) );