Compare commits
	
		
			2124 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 4fdd09a262 | ||
|  | d6878512c4 | ||
|  | 8b1b8250ff | ||
|  | 9dccbf747e | ||
|  | 08727e1938 | ||
|  | 7584820987 | ||
|  | d572356642 | ||
|  | 3b5a2815a9 | ||
|  | f3cf01df25 | ||
|  | 63e6e64ad3 | ||
|  | e8d7b48bff | ||
|  | 12944d1ebd | ||
|  | fa1ff6e393 | ||
|  | 98546b6e6a | ||
|  | 2fef6fd1fa | ||
|  | 20cf91f1dc | ||
|  | 2efa78d590 | ||
|  | 880af0671a | ||
|  | 62471e4531 | ||
|  | b15f8535f8 | ||
|  | 7a3a4493da | ||
|  | 11078235c4 | ||
|  | f3e05cd08a | ||
|  | 0ca3cabbe8 | ||
|  | 44a75c1291 | ||
|  | 4a4513a746 | ||
|  | 60ff8660de | ||
|  | 6fa0d671c0 | ||
|  | f478d7c9f0 | ||
|  | 53e3e08d70 | ||
|  | c4d1ccb6f5 | ||
|  | e3520309fc | ||
|  | 27bf72372e | ||
|  | ae4b1b17a9 | ||
|  | 94cb03f4b5 | ||
|  | e691351976 | ||
|  | 3190de873e | ||
|  | e8a637498d | ||
|  | e1195ac00a | ||
|  | 6cd9ccc37c | ||
|  | 25345302e8 | ||
|  | eccd5e9801 | ||
|  | ff355af9f2 | ||
|  | 5967f4b0d4 | ||
|  | ff18618032 | ||
|  | 20f03c356c | ||
|  | 27fdc9e56e | ||
|  | 52d9578a19 | ||
|  | f4c2938b41 | ||
|  | 9f703de5ec | ||
|  | a327fd85e2 | ||
|  | 9d22a86ec8 | ||
|  | 29e0b194dd | ||
|  | ae9cf13fc2 | ||
|  | 64ae67586a | ||
|  | 838c7a5e89 | ||
|  | 89bfc90f40 | ||
|  | acad9f57f9 | ||
|  | 0d08dc410e | ||
|  | ebb3fb96cd | ||
|  | f31f23ff07 | ||
|  | d2aa3d1868 | ||
|  | c9e2fce94d | ||
|  | 8b0e76dd55 | ||
|  | 884618adfe | ||
|  | 98f7271ac8 | ||
|  | 087cd121b8 | ||
|  | 2d52527fb4 | ||
|  | fe289e62b5 | ||
|  | 2845475e3f | ||
|  | b307492487 | ||
|  | d48284f7ea | ||
|  | 7e416797e9 | ||
|  | 5d54ca7477 | ||
|  | b979b4e61a | ||
|  | 2527f7984a | ||
|  | d9350b2362 | ||
|  | bd0b903f1a | ||
|  | f243c0df19 | ||
|  | 7482978953 | ||
|  | 77966689d4 | ||
|  | cf43939d65 | ||
|  | 391ac4b351 | ||
|  | e1e48aadd9 | ||
|  | 0681f206c4 | ||
|  | d257c6f3d3 | ||
|  | fa45c82cdc | ||
|  | e805b58da6 | ||
|  | 943976d207 | ||
|  | 3a2e5a6ccd | ||
|  | 35ef036246 | ||
|  | e09c3bbdd3 | ||
|  | 3b12076d4b | ||
|  | cfcf78ae28 | ||
|  | 341ff9bf5c | ||
|  | 10d8ca30b0 | ||
|  | 4ebb5d099e | ||
|  | 1e82b66bf0 | ||
|  | 06a5e4273b | ||
|  | e123e7b0b0 | ||
|  | aeadc40c65 | ||
|  | 7ef418ec52 | ||
|  | 2ed52820b6 | ||
|  | e8fd7484b6 | ||
|  | ce5242cfe8 | ||
|  | af947879d8 | ||
|  | 3ed112cde6 | ||
|  | 99c6a9eccd | ||
|  | 2029f6ea0a | ||
|  | e984e1f30f | ||
|  | f21260370f | ||
|  | fdae75c99b | ||
|  | a0489f2a0d | ||
|  | 0123eacbdb | ||
|  | 53401b6aa7 | ||
|  | 9a5139f452 | ||
|  | 2ee0c8c228 | ||
|  | c53562cc9c | ||
|  | ec5d7c2e5c | ||
|  | d6fc258485 | ||
|  | f953612695 | ||
|  | 2ab93acca8 | ||
|  | 326c6c496e | ||
|  | 9f7f50664c | ||
|  | f6f1436123 | ||
|  | c3c519419d | ||
|  | e569a80b72 | ||
|  | 284f437c1a | ||
|  | 1fd44a9958 | ||
|  | cad34742f6 | ||
|  | 323359b3c8 | ||
|  | 35db8b45f0 | ||
|  | 50ae815ceb | ||
|  | 1a4389c90d | ||
|  | fdaa5ce1da | ||
|  | 09d9936aed | ||
|  | b3f6109b1c | ||
|  | 5fb3ffc240 | ||
|  | 360db252bb | ||
|  | 0b6e290271 | ||
|  | 7f0174e6db | ||
|  | a25dad6c2e | ||
|  | 6191a49ed3 | ||
|  | 6252b075bc | ||
|  | 7face138fd | ||
|  | 382b83b093 | ||
|  | 691687d1bc | ||
|  | 5814b80a72 | ||
|  | e147fbb1fa | ||
|  | b9e256adfa | ||
|  | 3b7bf04e22 | ||
|  | 43408a724c | ||
|  | 5fbd5bf9e2 | ||
|  | 5e87828b29 | ||
|  | 9066cedc29 | ||
|  | aa1cf0b228 | ||
|  | 06a6a4408f | ||
|  | d5619d2b9d | ||
|  | 2f6ac42efe | ||
|  | 0bba3dd83d | ||
|  | abe60b62e6 | ||
|  | 555b7df986 | ||
|  | b3786700e6 | ||
|  | ce9643d21b | ||
|  | 4a5cb7f2f5 | ||
|  | 42a7e902e6 | ||
|  | aebe080e85 | ||
|  | c316284924 | ||
|  | 8d98b228ab | ||
|  | 5b4c42ff05 | ||
|  | a596a4551a | ||
|  | 0968f96982 | ||
|  | 5931e13b9c | ||
|  | 415c768ae4 | ||
|  | b4c8bf21d5 | ||
|  | 5fe5db603d | ||
|  | 9f7dd7f5d4 | ||
|  | e6d32aab7b | ||
|  | 08bd6d963c | ||
|  | ff05fb14a6 | ||
|  | 22d942b705 | ||
|  | 0526372f28 | ||
|  | f99051906a | ||
|  | d1f7fd8bfd | ||
|  | fc1436a96d | ||
|  | d21568497b | ||
|  | df4beef060 | ||
|  | a52f195d41 | ||
|  | 419019a656 | ||
|  | 42b5635485 | ||
|  | a8fc5b01f3 | ||
|  | ead841d844 | ||
|  | 67d7930aef | ||
|  | 6f69995f4e | ||
|  | 05252fa239 | ||
|  | 1377439bb0 | ||
|  | 407123a280 | ||
|  | 750dd590c8 | ||
|  | 44112a9d18 | ||
|  | b220bf0d99 | ||
|  | d0d93d7070 | ||
|  | 4117961236 | ||
|  | 68a3d71ee6 | ||
|  | bf5d741f0d | ||
|  | 55a33bc408 | ||
|  | 3ec35ed119 | ||
|  | 3d8d6953ec | ||
|  | 528db67c34 | ||
|  | b847e962aa | ||
|  | bbb9a3c63b | ||
|  | 322cebc48c | ||
|  | 1cceb3d880 | ||
|  | effc64db9a | ||
|  | 7e5bd5f2c1 | ||
|  | e32cc4d1af | ||
|  | 09a3cd850e | ||
|  | b0c876019a | ||
|  | 6725f870d2 | ||
|  | 0e5adc1f0a | ||
|  | 57ebb93dc0 | ||
|  | 05dc0bfa1d | ||
|  | 2d0264116c | ||
|  | 3938550ea8 | ||
|  | 9f0c567794 | ||
|  | 8672fcd2bb | ||
|  | 3f2a92e801 | ||
|  | 771e43583a | ||
|  | 9353d5c1c4 | ||
|  | 5e462f0f02 | ||
|  | a25f6fec9f | ||
|  | 519edce0ed | ||
|  | 0bc7702d95 | ||
|  | 18be0d6d26 | ||
|  | 1d4a435f20 | ||
|  | 34e46fc6d3 | ||
|  | 50956c51f7 | ||
|  | dd7bb28b6a | ||
|  | 8516f41ba8 | ||
|  | 15c3cc60f6 | ||
|  | 716bca211b | ||
|  | 8179813fe1 | ||
|  | d355de509b | ||
|  | b04a2d4c08 | ||
|  | 6d3232a4f0 | ||
|  | 2753075180 | ||
|  | d0166b25e4 | ||
|  | 73ee657d74 | ||
|  | 45913e5ee8 | ||
|  | e6369820a9 | ||
|  | 22a5b339f7 | ||
|  | 2cea3b6435 | ||
|  | 5d2d06fb3e | ||
|  | 0dd7bc7fb9 | ||
|  | 0b0005337c | ||
|  | d26fb02bb9 | ||
|  | af683835d9 | ||
|  | c43647ca86 | ||
|  | 6d02e70025 | ||
|  | 5498c6f87d | ||
|  | 11f59bc3ac | ||
|  | 94cb7de79f | ||
|  | 838f45775b | ||
|  | 1c1422e4b5 | ||
|  | cd8ca6fc62 | ||
|  | b7a0a9d7c2 | ||
|  | 7822ab113a | ||
|  | e250a91f09 | ||
|  | 92a65dcda5 | ||
|  | 4b129d94e4 | ||
|  | e7960d1d44 | ||
|  | 95589307cd | ||
|  | 20a0e4f3e0 | ||
|  | 6a9213da64 | ||
|  | 7a89e3cf33 | ||
|  | 64607df929 | ||
|  | a62a1012fa | ||
|  | 14efd0b2f9 | ||
|  | 7ad2192df8 | ||
|  | 3cb5cbd8d5 | ||
|  | cc9011cd68 | ||
|  | dc3d89008d | ||
|  | 1893642187 | ||
|  | a9ece5772d | ||
|  | cf34716a57 | ||
|  | 1337831061 | ||
|  | 757e72100d | ||
|  | a75b819858 | ||
|  | da4a0f09ed | ||
|  | 87d847a074 | ||
|  | 84711beec0 | ||
|  | f3cf58c8ff | ||
|  | cf40497e6e | ||
|  | dfebc4b78d | ||
|  | 15f41a2e7c | ||
|  | ad6e55ca17 | ||
|  | 6b466d217a | ||
|  | 00dcb304c7 | ||
|  | c6fb3d6f41 | ||
|  | ac3143811f | ||
|  | 7e27dd7678 | ||
|  | c2508296a5 | ||
|  | a9b50ce6fc | ||
|  | eac98a6d4d | ||
|  | 7e2b2a9a02 | ||
|  | 353de471eb | ||
|  | 85fc20b52d | ||
|  | cc25a781f8 | ||
|  | fc3012ba72 | ||
|  | d93a92c1c8 | ||
|  | f7f795f58a | ||
|  | 2700f8cdd2 | ||
|  | 6310de0d20 | ||
|  | 218794be77 | ||
|  | af71ae649b | ||
|  | 9bc72c1a06 | ||
|  | 8d7c157751 | ||
|  | 558a66fbe5 | ||
|  | f95b414d22 | ||
|  | e793a1e1aa | ||
|  | b76010cb5a | ||
|  | 52475df783 | ||
|  | 1f3f32d377 | ||
|  | 3f5ba10354 | ||
|  | 25f4a018d9 | ||
|  | a11a279c00 | ||
|  | fd4fdb31b5 | ||
|  | 1921796d6d | ||
|  | 543a2b9dc7 | ||
|  | dd23e03342 | ||
|  | 5307c74f85 | ||
|  | d701c406e2 | ||
|  | 3ba56a0a65 | ||
|  | 4adafb6d1e | ||
|  | 4453a51211 | ||
|  | 14429d2943 | ||
|  | 1a62a7831b | ||
|  | 242e35c212 | ||
|  | ea763fdfd5 | ||
|  | e762b7ff48 | ||
|  | 298068b2b9 | ||
|  | cb4120ec4b | ||
|  | 5cfbb87bee | ||
|  | 9e472ed83c | ||
|  | ebca753fc4 | ||
|  | 548f45cd56 | ||
|  | 8ffabf1813 | ||
|  | 1f40d4f941 | ||
|  | 41582045d0 | ||
|  | fd9e3fc03a | ||
|  | 8c42b2bdb4 | ||
|  | 7b1787fdbb | ||
|  | 71fee0025d | ||
|  | 1204cf1ba0 | ||
|  | 7bd8d8c3ae | ||
|  | 2c4d5fa38d | ||
|  | bedb2d943e | ||
|  | a3640bd9bf | ||
|  | 7c0b9ffe06 | ||
|  | 161c7d30ca | ||
|  | 4ff6e792cd | ||
|  | af5df890a5 | ||
|  | 9ba011003a | ||
|  | bb168d35a8 | ||
|  | 3306d30094 | ||
|  | 6516e0dfd2 | ||
|  | 00a396014b | ||
|  | 13356047dc | ||
|  | 8a6488b067 | ||
|  | 1c2ea56f42 | ||
|  | 1d7ae300e2 | ||
|  | 6013e186ed | ||
|  | 207d3d3340 | ||
|  | 5a6cde1446 | ||
|  | 63f7d826bc | ||
|  | ff8773f6bd | ||
|  | a868cb97d9 | ||
|  | 915d73e6f2 | ||
|  | 5f4f6e37b5 | ||
|  | 9c350311e8 | ||
|  | 3c6ba72a2a | ||
|  | 816442f5f0 | ||
|  | 3b51d18ce7 | ||
|  | 6696b6661a | ||
|  | 8c87478636 | ||
|  | d870b072d7 | ||
|  | 2ea2af7d2a | ||
|  | f737ea96f3 | ||
|  | 05f90394db | ||
|  | c24b0c6bb4 | ||
|  | e07a4dc7ba | ||
|  | fc6748a46b | ||
|  | 7697c46652 | ||
|  | ed52e5afd1 | ||
|  | 33a5b84181 | ||
|  | c09a407f4c | ||
|  | d35784ec61 | ||
|  | 53e012f296 | ||
|  | 2a9d0a5e7d | ||
|  | 474f4572f2 | ||
|  | bf57cb209f | ||
|  | 9bc41c1709 | ||
|  | fe10b8650f | ||
|  | 3a311c9584 | ||
|  | d1106f53e0 | ||
|  | a3a1bba5ef | ||
|  | 028d66befc | ||
|  | bb59cd5742 | ||
|  | 604e3068b2 | ||
|  | 27f1d3b704 | ||
|  | d007623347 | ||
|  | 6a5cf7a1fa | ||
|  | 3adfe249b0 | ||
|  | 923893e160 | ||
|  | 256e5360d4 | ||
|  | 304c597a2f | ||
|  | f86d3a69d2 | ||
|  | d7c8adfd82 | ||
|  | 55cd069043 | ||
|  | 3ca0e9c420 | ||
|  | 1dd4323613 | ||
|  | d78916f85f | ||
|  | 1840d15397 | ||
|  | b98d1216b1 | ||
|  | 27db727321 | ||
|  | 3f6b1f6ccb | ||
|  | 6d633b372a | ||
|  | 91352e855a | ||
|  | 8bb9b594cf | ||
|  | 6d2fd2e641 | ||
|  | 422fbcb0b7 | ||
|  | afce106186 | ||
|  | f21c8154ed | ||
|  | 3988a648d6 | ||
|  | 1b632894d3 | ||
|  | 5e128f89f6 | ||
|  | fff0b15ae5 | ||
|  | a7e14f1093 | ||
|  | 94eeaeb8d3 | ||
|  | 64191e8303 | ||
|  | 21cfb71617 | ||
|  | 806457063f | ||
|  | b9213b73bd | ||
|  | d7f0102aa2 | ||
|  | f09e61a59a | ||
|  | d426aaa88a | ||
|  | 19e45389e1 | ||
|  | 6d2389945b | ||
|  | 14c48253f6 | ||
|  | e5ff25b92d | ||
|  | 5c88888e02 | ||
|  | 10057de9b3 | ||
|  | cc88ebd2b9 | ||
|  | 6baedf909d | ||
|  | f39d9d6f1b | ||
|  | ab61a95f83 | ||
|  | 10ceed30c6 | ||
|  | 2b9aa94f3a | ||
|  | 848fb975ed | ||
|  | d7f59dac84 | ||
|  | dd47e615ee | ||
|  | 8f2f7ea1a5 | ||
|  | 80a8efd8ce | ||
|  | d9dce77ef4 | ||
|  | ce7053a1fe | ||
|  | 0db1530171 | ||
|  | 3745504107 | ||
|  | 57533fd831 | ||
|  | f57a0d4d6b | ||
|  | 22772ca33e | ||
|  | dba6ff1d51 | ||
|  | 40146dedaf | ||
|  | 387b822f53 | ||
|  | b9a3563e5b | ||
|  | 3d6468326a | ||
|  | 298e37ec53 | ||
|  | 5b137c457b | ||
|  | 5218a3fbac | ||
|  | 4569cb432d | ||
|  | 611e598756 | ||
|  | 937d79d28f | ||
|  | 23c2a771d3 | ||
|  | 58a890e836 | ||
|  | 6a869e120c | ||
|  | ae7c298b1a | ||
|  | 53bfe12ac1 | ||
|  | 140ea683a6 | ||
|  | 0634a97598 | ||
|  | 3479c794de | ||
|  | 89cad116f7 | ||
|  | 19c84eb694 | ||
|  | eae390acf5 | ||
|  | 10567afbb9 | ||
|  | 51bad3bf3c | ||
|  | 9134d8841d | ||
|  | e9a026c131 | ||
|  | 9a2fd0e2b2 | ||
|  | 522f7e6844 | ||
|  | cb4f46decc | ||
|  | 81256279a8 | ||
|  | 039bd1ddc0 | ||
|  | 0791d4797f | ||
|  | 6a06142e1e | ||
|  | ef53dca062 | ||
|  | 6ce761edda | ||
|  | d8fd218409 | ||
|  | edc2310599 | ||
|  | b1cd13d629 | ||
|  | b81940351f | ||
|  | a42e99c4aa | ||
|  | ff40b521b7 | ||
|  | 85392496e7 | ||
|  | 29cae9975e | ||
|  | 170d6b28f8 | ||
|  | 9a8b404054 | ||
|  | 41af5187aa | ||
|  | a844ca161f | ||
|  | e09efba313 | ||
|  | 96a0dbea2d | ||
|  | 5b3b5271ad | ||
|  | d7d13c12fe | ||
|  | 54220d0e71 | ||
|  | 4a2e3586f1 | ||
|  | f808e85da9 | ||
|  | 1671d1f580 | ||
|  | 7de1bf9d95 | ||
|  | 7368b0cefb | ||
|  | 4af43d676a | ||
|  | 67dc848b2d | ||
|  | 7ec8f0d26b | ||
|  | eaf08a9971 | ||
|  | 5bdb9e972e | ||
|  | d4d87054c4 | ||
|  | 0f93929544 | ||
|  | 1c0e794f87 | ||
|  | f9bce5a5f9 | ||
|  | 797ae096c8 | ||
|  | 6d76918424 | ||
|  | 2aced893c6 | ||
|  | f0373cd789 | ||
|  | 2f88dc64fc | ||
|  | 781ca77794 | ||
|  | c6e453fb00 | ||
|  | a40b3dd377 | ||
|  | 096b3534d8 | ||
|  | 5324244c55 | ||
|  | 993f1dc853 | ||
|  | d8a4e9e1ab | ||
|  | b3ffd33507 | ||
|  | c93870316c | ||
|  | fc9906624e | ||
|  | ba6209ba54 | ||
|  | f9769a73fe | ||
|  | 3a2f56cb95 | ||
|  | a4d33879dc | ||
|  | e2a91d1ea9 | ||
|  | f30f80d117 | ||
|  | 266274135e | ||
|  | a10439b67c | ||
|  | 0fd8d0e2bf | ||
|  | 47e2707fd3 | ||
|  | f7bb4a7d60 | ||
|  | 6102a31a31 | ||
|  | 1692c3b102 | ||
|  | ac60725d2a | ||
|  | 1542f73fa5 | ||
|  | 70a22187f7 | ||
|  | 347e598715 | ||
|  | a737810c50 | ||
|  | 92654a71fb | ||
|  | 18615640e0 | ||
|  | b8c80a2310 | ||
|  | c34c98386e | ||
|  | d8a3d2793f | ||
|  | 360b0d9997 | ||
|  | 356f46aaf4 | ||
|  | 87ac0507d9 | ||
|  | 63657c18e2 | ||
|  | 817f92a50e | ||
|  | 304be96dd6 | ||
|  | 9639081e7e | ||
|  | dca553048a | ||
|  | 6201ed4d55 | ||
|  | 6db2c04585 | ||
|  | f3840512ba | ||
|  | 9a6cf58565 | ||
|  | 78076122ba | ||
|  | 7429f66d6b | ||
|  | e59eff83b9 | ||
|  | 2083d85afa | ||
|  | 4c9f1369c8 | ||
|  | adca1d7855 | ||
|  | dfc4e99560 | ||
|  | 344076c943 | ||
|  | 710f1e2ca0 | ||
|  | 74ea85d19c | ||
|  | dded98e30c | ||
|  | 160c27c15a | ||
|  | a6a9025bab | ||
|  | a780d4463c | ||
|  | 23539ee907 | ||
|  | b515df611d | ||
|  | 0d896fef0b | ||
|  | 283d5c64cb | ||
|  | 3134bc432b | ||
|  | fd93fef73e | ||
|  | 8939a9c786 | ||
|  | 52c0d360b2 | ||
|  | d99432bff1 | ||
|  | 4dd2d3ac7d | ||
|  | aa7fe3668c | ||
|  | 83ebcf1dae | ||
|  | c9317659c5 | ||
|  | 6562c558de | ||
|  | 303f67c036 | ||
|  | 2482d122b8 | ||
|  | 1733c38b5c | ||
|  | 7a1e4e9e99 | ||
|  | e590313297 | ||
|  | b63d243e33 | ||
|  | e9c1216d5c | ||
|  | df9e50445e | ||
|  | 61339face6 | ||
|  | 9cd751e977 | ||
|  | 7aa08ff885 | ||
|  | a824caf712 | ||
|  | 395210e4f0 | ||
|  | e23354b2bb | ||
|  | bc472eb0b3 | ||
|  | 256f8e7226 | ||
|  | f41959537b | ||
|  | c9e05cf9f6 | ||
|  | 82d9a02d92 | ||
|  | dc9fa81346 | ||
|  | b91c178200 | ||
|  | adebdf36a5 | ||
|  | 4f34980c9f | ||
|  | e70766a535 | ||
|  | 55110dfbac | ||
|  | 56405ac903 | ||
|  | 2b2136c468 | ||
|  | f12031ee9e | ||
|  | c26852da77 | ||
|  | d9dc171c28 | ||
|  | d407f31ae5 | ||
|  | f688b8d299 | ||
|  | d8e6a7b687 | ||
|  | 7c42b04eff | ||
|  | f527841c29 | ||
|  | 48a8dc0989 | ||
|  | 7e35c9c754 | ||
|  | 7502a2b1ff | ||
|  | 6c2de40dba | ||
|  | ef90f19eaa | ||
|  | 90ab34591a | ||
|  | 21d3a3dd1e | ||
|  | b44e70115b | ||
|  | ac31957707 | ||
|  | 65e27a268d | ||
|  | 6bd59b10c7 | ||
|  | 6a6a692891 | ||
|  | 479b18354d | ||
|  | 9c6452544b | ||
|  | 0a6ff900da | ||
|  | f54f863611 | ||
|  | 9cc04da7b2 | ||
|  | d7f5b0c9d7 | ||
|  | 9bd4598c6a | ||
|  | e3b052bc38 | ||
|  | f215970649 | ||
|  | dfe1cd4f90 | ||
|  | 3d2e6aea7b | ||
|  | 749b0d7019 | ||
|  | 7978f85f7a | ||
|  | bd14acb68a | ||
|  | 1e9ce550db | ||
|  | 6278dfa77e | ||
|  | 2a3e355437 | ||
|  | f6b0459d27 | ||
|  | 790d6912fd | ||
|  | e69e5b4f50 | ||
|  | 483306e73c | ||
|  | 1148a0b637 | ||
|  | 524021f0fa | ||
|  | 5b5f9aa01d | ||
|  | f97f92c297 | ||
|  | 9d4139085b | ||
|  | 0ee7ffb5e5 | ||
|  | 8a7bb1be9f | ||
|  | d4135e80a6 | ||
|  | a5ade39d7c | ||
|  | f39b4e7d22 | ||
|  | 080469cdf5 | ||
|  | 835ad29417 | ||
|  | c09bea4710 | ||
|  | 879c0f4114 | ||
|  | 5feb07583b | ||
|  | 5388002f54 | ||
|  | c80fa9914b | ||
|  | b43d566968 | ||
|  | 6b4e15dd0f | ||
|  | d9ef32d7e8 | ||
|  | 49389d6f06 | ||
|  | c75dc3cc36 | ||
|  | c0eabf0438 | ||
|  | 7730d0a4f8 | ||
|  | e79da408a8 | ||
|  | 7381784d0f | ||
|  | 085fb283e5 | ||
|  | 61e0e50e7b | ||
|  | 00460d856b | ||
|  | 48958f392f | ||
|  | a84efeb5d5 | ||
|  | 1c8c05ae04 | ||
|  | 401d386812 | ||
|  | 6b07f58e8e | ||
|  | 6e8c978d12 | ||
|  | 5b2296b056 | ||
|  | dbf0486acb | ||
|  | b030e935ce | ||
|  | 29bd43413a | ||
|  | 2249b9449c | ||
|  | 30920b1b78 | ||
|  | 8f92a3e875 | ||
|  | ed1a55d9cd | ||
|  | 93ef84f495 | ||
|  | ccfcbe8526 | ||
|  | 5938143002 | ||
|  | 8135da71bd | ||
|  | a3c73a04c2 | ||
|  | 7f90d31846 | ||
|  | 45fbd22e28 | ||
|  | 4689d56955 | ||
|  | aa1b2808e7 | ||
|  | 40ad4bdbd8 | ||
|  | b6510d66e0 | ||
|  | 4ea33ea482 | ||
|  | e13d410b4a | ||
|  | 72da7e6c54 | ||
|  | fb05960d79 | ||
|  | 7bd0943412 | ||
|  | bb2649d063 | ||
|  | d743bdbf5a | ||
|  | 61890f19bc | ||
|  | b756a8edef | ||
|  | adcb2f1aa8 | ||
|  | e574f4516f | ||
|  | 2ac9c11ec9 | ||
|  | 1c470ab9e3 | ||
|  | 08b8a8e3af | ||
|  | 11ee1a7dcb | ||
|  | a281b8c74e | ||
|  | 5cb37148c6 | ||
|  | 05878d3176 | ||
|  | d1c42262d6 | ||
|  | 8dcc114873 | ||
|  | c54cf26848 | ||
|  | bfb548636e | ||
|  | 36e1b2ba08 | ||
|  | 301ac279ff | ||
|  | 08d21ccba7 | ||
|  | 62876ca377 | ||
|  | 10f94148af | ||
|  | 31502c2ebc | ||
|  | 62b29ecb65 | ||
|  | 67337e013a | ||
|  | f987fa13ea | ||
|  | 73dfe631ce | ||
|  | 83ca8147ca | ||
|  | 1c11e7f97b | ||
|  | aefae79186 | ||
|  | 4b05a9bb6f | ||
|  | 2453719a87 | ||
|  | ea929b00e3 | ||
|  | ede940a398 | ||
|  | 67da853146 | ||
|  | 624befd704 | ||
|  | 203539841d | ||
|  | 262db23f7d | ||
|  | 28ea22f0e1 | ||
|  | 3f349c3531 | ||
|  | 9928e8562a | ||
|  | b1e3fc5761 | ||
|  | b2390f1caf | ||
|  | 8cc9aeba4a | ||
|  | ba0823c38c | ||
|  | b9379f2ddf | ||
|  | 38a950a6dc | ||
|  | fb24dca019 | ||
|  | 07d131c945 | ||
|  | 0c1c710afe | ||
|  | 15cd93c30f | ||
|  | a5d9e17a8c | ||
|  | a82926dd0d | ||
|  | 12435b997a | ||
|  | 5945be95cf | ||
|  | 5c2e7ce407 | ||
|  | 834e894b1d | ||
|  | d25dac69d2 | ||
|  | 3cc4173399 | ||
|  | 36ab16c1ed | ||
|  | 5356373681 | ||
|  | f45a2643f2 | ||
|  | e55933706d | ||
|  | 3b3d696e45 | ||
|  | 281351e6b3 | ||
|  | 34089aec70 | ||
|  | 3658d0e039 | ||
|  | 7a10636128 | ||
|  | 604ba7f4bc | ||
|  | 27b7fb54e8 | ||
|  | d351aa842c | ||
|  | 59da705b8f | ||
|  | 99b8f16d88 | ||
|  | 06ffe722d4 | ||
|  | 6264104642 | ||
|  | c97812c340 | ||
|  | bd4c578230 | ||
|  | 6ec2949b6f | ||
|  | 1ff23ebfd9 | ||
|  | 7698990e37 | ||
|  | 17e092afb3 | ||
|  | 2db65b9d1f | ||
|  | c6436f47eb | ||
|  | e88b4a4412 | ||
|  | 01a177adfb | ||
|  | 052b5e0ea8 | ||
|  | 68cd447109 | ||
|  | 4a8a5ed8d4 | ||
|  | 84077505b0 | ||
|  | c4554b71d3 | ||
|  | 63ce743571 | ||
|  | 6cf53c611b | ||
|  | d8720ee325 | ||
|  | 73501f3ad3 | ||
|  | 54ee655472 | ||
|  | 571b9fb8e0 | ||
|  | cdd6b243ff | ||
|  | fca77a868f | ||
|  | 424e854778 | ||
|  | 0979d565bb | ||
|  | f5e6ca3e10 | ||
|  | 2bde07561f | ||
|  | 16c92cc739 | ||
|  | 8b31a918a4 | ||
|  | ee0bd49918 | ||
|  | a625eeeac8 | ||
|  | bfcd795687 | ||
|  | e2a9be9cec | ||
|  | 37dd075309 | ||
|  | 89769fb0e5 | ||
|  | b24fac3dd8 | ||
|  | 4794fe495c | ||
|  | 869fdbcc6a | ||
|  | 702e6d3b51 | ||
|  | 2913e13a30 | ||
|  | 5f1e37b7fa | ||
|  | ec0209b175 | ||
|  | a17dcbde0f | ||
|  | fbd159a23a | ||
|  | 599a6bf050 | ||
|  | 185b16a858 | ||
|  | e7e3ed4923 | ||
|  | 47df5476ba | ||
|  | d7c516ab00 | ||
|  | 50838970ec | ||
|  | 1d15ee7034 | ||
|  | 7029541b4f | ||
|  | ada8e447cc | ||
|  | 1841fc18fa | ||
|  | 94ee465682 | ||
|  | 3e021b3a75 | ||
|  | 0643f149b7 | ||
|  | 939768eec0 | ||
|  | f2235dacdc | ||
|  | 50017c28da | ||
|  | 85b2a03a42 | ||
|  | 829087550d | ||
|  | dd6f71fe85 | ||
|  | 92a928680c | ||
|  | d008b1970c | ||
|  | 4affbb8c6b | ||
|  | ddb2ea4b5f | ||
|  | a69683183f | ||
|  | 8d34f87667 | ||
|  | 128c4fe222 | ||
|  | b10141d71f | ||
|  | 68e0b35364 | ||
|  | 1324f5e59c | ||
|  | 7759aacb35 | ||
|  | fd6f7cd881 | ||
|  | 3fdeb38bb7 | ||
|  | e27f5d0460 | ||
|  | 0720128bd4 | ||
|  | 540472a093 | ||
|  | daca78b6cd | ||
|  | 4195840b2c | ||
|  | 57c529758e | ||
|  | 5ba9a0eb3f | ||
|  | b8888a5d46 | ||
|  | 0857f979ff | ||
|  | 11f4ae019c | ||
|  | 0ffeb0c5af | ||
|  | d6f6b41145 | ||
|  | 64daaeb310 | ||
|  | 0646b0060e | ||
|  | c794ca85fd | ||
|  | 5b4019dd3d | ||
|  | a03ccd7b59 | ||
|  | 4b64aad5ce | ||
|  | d146ff8794 | ||
|  | 5349bf7628 | ||
|  | a79e4d1bb3 | ||
|  | f462435dc2 | ||
|  | 48ad614441 | ||
|  | f699516fdb | ||
|  | ca5cbb640a | ||
|  | 0a96259ddf | ||
|  | d99b9c04e4 | ||
|  | 64d261e053 | ||
|  | eb027d98aa | ||
|  | a95727b654 | ||
|  | 4e636d7eec | ||
|  | 3cd53f617a | ||
|  | b1684e82d8 | ||
|  | a55027b838 | ||
|  | 28678acf74 | ||
|  | ce6594c8cc | ||
|  | 75855d5450 | ||
|  | f248699a30 | ||
|  | 29594726ca | ||
|  | 0a41b07297 | ||
|  | e45cb7fac1 | ||
|  | 489dbfc72a | ||
|  | a89ae7d77a | ||
|  | a1eeff4034 | ||
|  | 0e1013a570 | ||
|  | 4562b06a60 | ||
|  | 3c96218338 | ||
|  | f0a4ea099c | ||
|  | c8d6693fba | ||
|  | 81bbdfe413 | ||
|  | 0e362943bf | ||
|  | 1e37fed90b | ||
|  | aafcfef387 | ||
|  | 4b83d8160f | ||
|  | 73a41707e5 | ||
|  | c989c533e8 | ||
|  | 707dc8c65c | ||
|  | 4c6157a06e | ||
|  | f973396821 | ||
|  | e73216d4c1 | ||
|  | e6de26736b | ||
|  | d131addd63 | ||
|  | 0c7705beff | ||
|  | 08b11addec | ||
|  | 555f96cfaf | ||
|  | 59ffacb3df | ||
|  | 83acb66f00 | ||
|  | 1f9ae45875 | ||
|  | ffa628be2d | ||
|  | 8916f6f829 | ||
|  | 215c8fd261 | ||
|  | 061cc908a7 | ||
|  | 18a519f9ed | ||
|  | 7970c9dbe5 | ||
|  | 5ca0c066e2 | ||
|  | 563728c7b8 | ||
|  | 31a72b6562 | ||
|  | d3dfbc3034 | ||
|  | f143a6ba08 | ||
|  | 28a65923b6 | ||
|  | 4ca3df77b3 | ||
|  | 4cbe264869 | ||
|  | b6b65b6bf7 | ||
|  | e7cc42a927 | ||
|  | bba3ca8cc0 | ||
|  | 8423e2d245 | ||
|  | fc263718a1 | ||
|  | c3a99cf5a4 | ||
|  | f6820ec615 | ||
|  | 226ad3fe22 | ||
|  | a9b17e930c | ||
|  | 932ea7ba8f | ||
|  | c720d78c39 | ||
|  | 8d21e441a0 | ||
|  | 16ecb1a9cb | ||
|  | f68acca427 | ||
|  | 671d7e2beb | ||
|  | 52fc497412 | ||
|  | 2084ad318f | ||
|  | b530c1a43d | ||
|  | f2797a4153 | ||
|  | 659c326f89 | ||
|  | 534b07d120 | ||
|  | de64fc8b8d | ||
|  | 1e234fcb73 | ||
|  | fa9a7e725b | ||
|  | 95b2675f03 | ||
|  | 564902b886 | ||
|  | 071a04595a | ||
|  | eaa4b76ede | ||
|  | 74a1713e99 | ||
|  | 5f5aa0b2f7 | ||
|  | eef59fd40e | ||
|  | 361ff315e9 | ||
|  | eeea8e530e | ||
|  | 8d5286703f | ||
|  | 74f2180fa4 | ||
|  | d042169f2e | ||
|  | 1fd87bf664 | ||
|  | eeaff6b553 | ||
|  | 6efd048fd6 | ||
|  | 6e9e694f66 | ||
|  | 44a0f1b505 | ||
|  | 9790211891 | ||
|  | be18cc9f2d | ||
|  | 8caee09ea4 | ||
|  | 26f5305593 | ||
|  | d33029027f | ||
|  | 339aaaec57 | ||
|  | db2425c473 | ||
|  | 18731f6055 | ||
|  | 34f1f7a31d | ||
|  | 7ef153756b | ||
|  | bf90509526 | ||
|  | d853eca489 | ||
|  | 869ae01da9 | ||
|  | d63996eea1 | ||
|  | 9bbc8eda9d | ||
|  | 9cc1b03c56 | ||
|  | b1ab26e3ad | ||
|  | 96820418b5 | ||
|  | 385d9f16e9 | ||
|  | d56fce37dd | ||
|  | aef2c9e5cf | ||
|  | 89a05c580f | ||
|  | b85e562980 | ||
|  | a0e6628757 | ||
|  | 60a41524f0 | ||
|  | 6042395b81 | ||
|  | 8a5db8ce4b | ||
|  | 196d6e79e2 | ||
|  | 91f16215e5 | ||
|  | 9c675a7847 | ||
|  | f9e09e87d6 | ||
|  | 73574d6293 | ||
|  | 0a5a42b32a | ||
|  | de225205bd | ||
|  | 8a47d36480 | ||
|  | d5f3ba8d8a | ||
|  | 782a06ce84 | ||
|  | 5cdafc50fb | ||
|  | 0ca3cdb9ae | ||
|  | a1d6cbd5fd | ||
|  | 6c36778cac | ||
|  | 1c3a97a71a | ||
|  | 3489fe0cf4 | ||
|  | 74b6d9dff9 | ||
|  | 06ee9aa05c | ||
|  | f0f40a8606 | ||
|  | 1f2c9879bd | ||
|  | d1eb82bdf6 | ||
|  | 8167f623e3 | ||
|  | 9555e296a2 | ||
|  | f460283fa1 | ||
|  | 79da8e5a37 | ||
|  | a35ce22218 | ||
|  | 1c905da8c2 | ||
|  | 2b558768f1 | ||
|  | 7607c4c882 | ||
|  | c9f4813ce1 | ||
|  | 0428e27039 | ||
|  | e30da2168d | ||
|  | 0cd20768f4 | ||
|  | ab31f34862 | ||
|  | 9a4ff5cb43 | ||
|  | f66c91e18e | ||
|  | a235745be7 | ||
|  | 9516da01e3 | ||
|  | 7657bd2375 | ||
|  | 0adcea9e7c | ||
|  | aa8ad60083 | ||
|  | 5d98a86a6b | ||
|  | 4418fdaed6 | ||
|  | c58c45c917 | ||
|  | 45eba5cabd | ||
|  | 3ab0d0d865 | ||
|  | a6803081ab | ||
|  | 8debed805b | ||
|  | fc9835512d | ||
|  | 5f0cab8cc2 | ||
|  | bd391963bc | ||
|  | 97fa28fb10 | ||
|  | 67d5b39c96 | ||
|  | dbceef2581 | ||
|  | 5b22ccfca6 | ||
|  | 714c254bab | ||
|  | 90f4db9158 | ||
|  | eed470ddae | ||
|  | 49f72881f4 | ||
|  | a76674032d | ||
|  | ec392a7f9a | ||
|  | 8a2ae6c480 | ||
|  | b3796a8e24 | ||
|  | b9144ff987 | ||
|  | 5344949c71 | ||
|  | 05cbba9a35 | ||
|  | 325c6135cf | ||
|  | fdea19a45b | ||
|  | fad63c0c18 | ||
|  | f002560616 | ||
|  | 8e7d52e645 | ||
|  | d119594cbf | ||
|  | 84f7da6e93 | ||
|  | 22e1bafe1b | ||
|  | 3f8e42e510 | ||
|  | 9704fb04d9 | ||
|  | dcfaf1e2b9 | ||
|  | 42f7dc1947 | ||
|  | eb1a597456 | ||
|  | 8368815db5 | ||
|  | 9c6295d0d8 | ||
|  | 4d19f881e9 | ||
|  | 3a8820397b | ||
|  | 85b1c1fe97 | ||
|  | a4de9e94dd | ||
|  | 0dd2c7fe24 | ||
|  | f22c3b549e | ||
|  | 3c60b3d2c9 | ||
|  | f2d36b84b5 | ||
|  | 9af08ef26a | ||
|  | b4be1184fd | ||
|  | c60e0d389c | ||
|  | d658fe7709 | ||
|  | 54036a2b4d | ||
|  | 2da9572a45 | ||
|  | 306825aa90 | ||
|  | c797073c05 | ||
|  | d9d65d59d1 | ||
|  | aad29e4487 | ||
|  | b00985f99f | ||
|  | 538a16a5fb | ||
|  | 300a8d3a89 | ||
|  | e3b7c5fce7 | ||
|  | 2e87ebe800 | ||
|  | 7ed9e7cdd4 | ||
|  | 7ff9c2885d | ||
|  | 18c8bbb0fc | ||
|  | 9a49fb9450 | ||
|  | 84457bc7b4 | ||
|  | 15f1e2c85c | ||
|  | 15e828e975 | ||
|  | e4626ee52b | ||
|  | 1866c9c7ef | ||
|  | a0f91aa814 | ||
|  | a89c7b1a70 | ||
|  | ded1376957 | ||
|  | 252040f03b | ||
|  | d29abc2724 | ||
|  | 44c35d2644 | ||
|  | f9b972349d | ||
|  | e06cadd761 | ||
|  | ee45d6b48f | ||
|  | d915b280d4 | ||
|  | 39d90fe881 | ||
|  | b9da1f18b4 | ||
|  | 69a0934173 | ||
|  | 289de85754 | ||
|  | 0ec95041d9 | ||
|  | fcb6f78d54 | ||
|  | 29e9740668 | ||
|  | ea8c6d5cce | ||
|  | e4c951984a | ||
|  | 0071afb205 | ||
|  | d3c7ac75be | ||
|  | 55d7420abf | ||
|  | 489b56456f | ||
|  | 1f24fcb364 | ||
|  | 722b31edee | ||
|  | 765f0393b0 | ||
|  | 6868ef044b | ||
|  | 5dd0622e40 | ||
|  | 48bdab1dcf | ||
|  | aee483e9f1 | ||
|  | 8542b9bf67 | ||
|  | feaf6f2501 | ||
|  | d7d30aa972 | ||
|  | 91c23d1f7d | ||
|  | 57479edc59 | ||
|  | 4b462eaae9 | ||
|  | c60fb3bc25 | ||
|  | b17c34402d | ||
|  | 6ad71bd222 | ||
|  | ccc08be0ee | ||
|  | 2a2fc80931 | ||
|  | 9ebca91775 | ||
|  | 456fc23463 | ||
|  | eb17562f4d | ||
|  | b7dbfd5cfc | ||
|  | cdc7ab562a | ||
|  | e6b5552cba | ||
|  | eecf92183f | ||
|  | 11656382a7 | ||
|  | e4d788ad0b | ||
|  | 3017442702 | ||
|  | ba37db275c | ||
|  | 521e669879 | ||
|  | 12e302c10a | ||
|  | 7220af3ef0 | ||
|  | 42f4e0fa86 | ||
|  | 022d066fe0 | ||
|  | 4c9d7cbeed | ||
|  | 1541e382e4 | ||
|  | 1d9488d24f | ||
|  | 6cbc1afb9b | ||
|  | 3f86b660ed | ||
|  | 4603f2d9ca | ||
|  | da818cf420 | ||
|  | 86a2ed652d | ||
|  | 269761f222 | ||
|  | 53ca3046b3 | ||
|  | f484156d8e | ||
|  | 1da8712a4a | ||
|  | dd47eba88c | ||
|  | 0ade8ff7a2 | ||
|  | 6a528b5fdb | ||
|  | 7f63ddc9ea | ||
|  | d6b326c134 | ||
|  | d944298dd7 | ||
|  | 0136ebd2b4 | ||
|  | 45f8def1ed | ||
|  | 7c6e8eeefc | ||
|  | e81e48cde3 | ||
|  | 8eebb6ea2d | ||
|  | ad8290ebcb | ||
|  | 15b6f6268b | ||
|  | 92d5af7446 | ||
|  | d57425a15e | ||
|  | a457c06500 | ||
|  | 906bbae899 | ||
|  | e360e57a5b | ||
|  | c5753a013c | ||
|  | 691b083364 | ||
|  | b74a35b9d1 | ||
|  | 82269462a4 | ||
|  | d7943aab28 | ||
|  | 446eb8e978 | ||
|  | d91a99c833 | ||
|  | dc00870461 | ||
|  | b8f578862e | ||
|  | dc24c05229 | ||
|  | f62cf6818b | ||
|  | c05e9da9c5 | ||
|  | 6c00194d35 | ||
|  | 6bc3f82afe | ||
|  | 12e46deea2 | ||
|  | 8608d010b8 | ||
|  | 9d4d1acf2d | ||
|  | 23087447f1 | ||
|  | 3008e4e60f | ||
|  | 9d52ed5ff6 | ||
|  | 5f047633c3 | ||
|  | d3be1f1e2c | ||
|  | c3b1cf7c35 | ||
|  | 682345da22 | ||
|  | 82f289c42e | ||
|  | 78eae99bd4 | ||
|  | 9ec7bb8d41 | ||
|  | 2b9bfbc309 | ||
|  | e50d04077b | ||
|  | b6fcaacb77 | ||
|  | 939da4e551 | ||
|  | f30ce1f9eb | ||
|  | 343588b2a0 | ||
|  | 77b13ce9d4 | ||
|  | 7cb41d2ca9 | ||
|  | 8bbc9e6502 | ||
|  | e29a0df3fd | ||
|  | 0eba04aac0 | ||
|  | b78210e3be | ||
|  | 958de21be8 | ||
|  | 0eb4742982 | ||
|  | 78b1bf8f25 | ||
|  | 08f2741871 | ||
|  | 98b24ae630 | ||
|  | 7fc056c8e3 | ||
|  | 0411623857 | ||
|  | 365d71264f | ||
|  | 0d4d51fc39 | ||
|  | b21745808b | ||
|  | e4d5271d58 | ||
|  | 8f2f3bf75d | ||
|  | 9e96eba98f | ||
|  | 0441c83fd7 | ||
|  | d8405052d8 | ||
|  | cc02b07ff0 | ||
|  | 2d6aac7d6f | ||
|  | 589d43f0e5 | ||
|  | 13c1d1df7a | ||
|  | 08ade44dc8 | ||
|  | 8fb1c76247 | ||
|  | 3ad9053d65 | ||
|  | 8fe07e0f07 | ||
|  | 09b069c129 | ||
|  | b2db083f39 | ||
|  | 53e2f3e263 | ||
|  | 945fbbc065 | ||
|  | 4dc9c7714c | ||
|  | 7302ac5871 | ||
|  | 1cfad27d6f | ||
|  | d82fe95076 | ||
|  | 8f8df4971c | ||
|  | fd66569950 | ||
|  | e97d9fb0b2 | ||
|  | 04424c2a7c | ||
|  | 241e2828e7 | ||
|  | 5f6a0141f0 | ||
|  | ef2f71859c | ||
|  | fdaeeb5d01 | ||
|  | e594ffe0f8 | ||
|  | 9f8c32ce8f | ||
|  | 762eb07dd4 | ||
|  | 0300458ba8 | ||
|  | 3959fcdc88 | ||
|  | ea76c18f59 | ||
|  | d125ecc671 | ||
|  | 7d9b90a1f3 | ||
|  | 7402c27b6a | ||
|  | 4e762e2063 | ||
|  | 0afe98b399 | ||
|  | daed059c47 | ||
|  | f1ce0fab8b | ||
|  | b5d3f505e3 | ||
|  | 6c8f688f33 | ||
|  | ed1b601a84 | ||
|  | add541f67f | ||
|  | bea8eb799f | ||
|  | 3cac48e86f | ||
|  | 64722da4a7 | ||
|  | ada1e624d8 | ||
|  | 69f83cb905 | ||
|  | 807873f685 | ||
|  | 8d4be848b0 | ||
|  | 59a7c46482 | ||
|  | eabfeb9502 | ||
|  | 291240dd94 | ||
|  | 2f6ed47168 | ||
|  | 9a73568c7a | ||
|  | acdef87be7 | ||
|  | b14546605d | ||
|  | 5ad46106f4 | ||
|  | 3e9be9eed3 | ||
|  | 7318a7b767 | ||
|  | b78682f413 | ||
|  | e50659af09 | ||
|  | 3454e5ac77 | ||
|  | 9e26aeea1d | ||
|  | d7715b05ee | ||
|  | db433efbef | ||
|  | f1f8c887c6 | ||
|  | 9ae4745ca5 | ||
|  | 726d9c8ec5 | ||
|  | a9bfa4e79b | ||
|  | 8e6bba143a | ||
|  | feeba77f16 | ||
|  | ea41a0e842 | ||
|  | 74b7500181 | ||
|  | 594ff8cd3d | ||
|  | 337f5f9b98 | ||
|  | 41445a1b48 | ||
|  | 269763fa0c | ||
|  | fa90eeac55 | ||
|  | edceffdaaf | ||
|  | ce25fc658b | ||
|  | b27db3e2e7 | ||
|  | 622d4214f7 | ||
|  | 0c53b5310a | ||
|  | 45ff86eae5 | ||
|  | 47316b0fb7 | ||
|  | c09be02e4e | ||
|  | bd59398cab | ||
|  | 8080ebceb4 | ||
|  | 1e2521c37a | ||
|  | b744491dd2 | ||
|  | 2a089f7d90 | ||
|  | 088e3e5374 | ||
|  | bac8a3092f | ||
|  | e56da17957 | ||
|  | 71b2e714ee | ||
|  | 1b06afb81c | ||
|  | 819e48b03a | ||
|  | 1861c1feb6 | ||
|  | 0efccc4758 | ||
|  | a9feeaa1c9 | ||
|  | f9c869f521 | ||
|  | 9c766d76f3 | ||
|  | 333acccff6 | ||
|  | 1790ebf567 | ||
|  | 6354b68bae | ||
|  | 41b10fd5e4 | ||
|  | 4ad540412a | ||
|  | 8916cf273e | ||
|  | b2923d0fc4 | ||
|  | 8fc0018cb9 | ||
|  | d0f57efe0b | ||
|  | 595ff63b72 | ||
|  | 9990046abb | ||
|  | 8dacf72b3c | ||
|  | 2801838ffa | ||
|  | 59b34c2b3f | ||
|  | f55f85aa14 | ||
|  | 627a80419a | ||
|  | 4bc482bc85 | ||
|  | 0a1257a23a | ||
|  | 51d99248d7 | ||
|  | af9aa74337 | ||
|  | 321f5e615b | ||
|  | 95c31f3e17 | ||
|  | cf69dbe1dc | ||
|  | e92241bf97 | ||
|  | 44dc37ef6d | ||
|  | 6b0bef61a5 | ||
|  | 0c227be02d | ||
|  | 08794bad74 | ||
|  | 44693dd23a | ||
|  | 75a7be41eb | ||
|  | 913b09570c | ||
|  | 1c9b5dfd00 | ||
|  | 2954ae917b | ||
|  | 736ddaeca4 | ||
|  | b909e32201 | ||
|  | bcff74327b | ||
|  | e60b63e72f | ||
|  | 2bf5d2b4e5 | ||
|  | e1d09349ff | ||
|  | f07c8108fc | ||
|  | 39f5078d6b | ||
|  | 1d54761d48 | ||
|  | 7cb9b2da66 | ||
|  | b1896e3737 | ||
|  | 6fa78bdb04 | ||
|  | ee96f7d937 | ||
|  | 129ca0e39f | ||
|  | 906703db5f | ||
|  | 0cd4a2b4ec | ||
|  | aef8aaa0bd | ||
|  | 428fbb8622 | ||
|  | b9f03e7d80 | ||
|  | db686388b9 | ||
|  | 626cba4002 | ||
|  | 37d4a6b9e2 | ||
|  | 12c4561aba | ||
|  | fed49e3718 | ||
|  | 3af37d3984 | ||
|  | 0f49a11228 | ||
|  | 27d3e165b0 | ||
|  | e941c22f6c | ||
|  | 7281e4deb6 | ||
|  | f2191e94b3 | ||
|  | 349ebfe4db | ||
|  | 708365c4ac | ||
|  | 0e9ea0aff1 | ||
|  | 63ba05a193 | ||
|  | 4b702815cf | ||
|  | 55e66ebcac | ||
|  | dcd8b3699c | ||
|  | 0e2d13172a | ||
|  | 2e2556fdad | ||
|  | 859a7538e1 | ||
|  | 0d1543ee8a | ||
|  | d3a98dd355 | ||
|  | ad10125303 | ||
|  | b89e866d39 | ||
|  | afbaf1cfe0 | ||
|  | b3be8b30e7 | ||
|  | 8bfab8f73d | ||
|  | c6ad2c9ad2 | ||
|  | 3b44d9972e | ||
|  | af736c98f2 | ||
|  | f1377fa217 | ||
|  | 2ba146b9ff | ||
|  | 2361607aa3 | ||
|  | 86ffc80098 | ||
|  | 7f6915eb59 | ||
|  | d69bcad028 | ||
|  | 4cb45e2712 | ||
|  | b7a0ad703a | ||
|  | 7610b9a975 | ||
|  | 7d95f621df | ||
|  | bba210e112 | ||
|  | 3a97e20bde | ||
|  | 4fe7ea00b0 | ||
|  | 3ec8ecd4de | ||
|  | 401e65e852 | ||
|  | e7c5b691a0 | ||
|  | 9f3ea8da67 | ||
|  | d1269b441d | ||
|  | 7615743aa5 | ||
|  | dcaa0eeea4 | ||
|  | 1d5e2f703e | ||
|  | 4d84d624b1 | ||
|  | 633a6a0ee6 | ||
|  | c7bcd3f438 | ||
|  | d3a29a6f16 | ||
|  | 827711ca89 | ||
|  | 76e98f74fa | ||
|  | fb09f4b22d | ||
|  | bb06585748 | ||
|  | c76ba1dcc7 | ||
|  | a115301b04 | ||
|  | 72917117a9 | ||
|  | 6567739236 | ||
|  | 4aa6b47c0e | ||
|  | 03558b012c | ||
|  | 3288efdad6 | ||
|  | 3902a343f3 | ||
|  | 882b7d0391 | ||
|  | 81f082825d | ||
|  | 392fd6fed3 | ||
|  | 51afed4041 | ||
|  | 17e3b71d9c | ||
|  | 6e75089f3a | ||
|  | 6dc640b129 | ||
|  | 27cbaac343 | ||
|  | fa4006619e | ||
|  | cb8fe8462a | ||
|  | abd51a5511 | ||
|  | a0cc1e6b0c | ||
|  | 50399c6bfa | ||
|  | de48c1be44 | ||
|  | 0786ec4b66 | ||
|  | db319e0ebc | ||
|  | 4fc568856a | ||
|  | 4c6771669b | ||
|  | 9bca2a91c9 | ||
|  | 66eaaf5a48 | ||
|  | 9837f0e2e1 | ||
|  | 6b8ffb4c68 | ||
|  | f35dd34da9 | ||
|  | ed19e4fa08 | ||
|  | 661e1a4f90 | ||
|  | 5826de76ca | ||
|  | 05888740e5 | ||
|  | 41f3b0c333 | ||
|  | 70f3e72a20 | ||
|  | e873afd40b | ||
|  | 2777c2937a | ||
|  | 798903e4cc | ||
|  | 58622ba18f | ||
|  | c368dcd5b7 | ||
|  | 0b4c652ce7 | ||
|  | dbaacc411a | ||
|  | 1850185d1e | ||
|  | 2e9d445d36 | ||
|  | aed89d82fb | ||
|  | 231adac6d8 | ||
|  | 587c4e5915 | ||
|  | 55f1cbf18f | ||
|  | 38168a545b | ||
|  | 43c6df49d7 | ||
|  | f1c59faf72 | ||
|  | 5f7019325c | ||
|  | fe4dae8518 | ||
|  | 1f848b205b | ||
|  | 742c470d81 | ||
|  | 5ead3342cc | ||
|  | b95dc2ecce | ||
|  | 4d0950215f | ||
|  | da0ce9fe0d | ||
|  | ca62e720b5 | ||
|  | c4b1795396 | ||
|  | fd2e47ed73 | ||
|  | d5f2255a68 | ||
|  | 05b58e9263 | ||
|  | 4a91c27e4b | ||
|  | 3a03d46d8d | ||
|  | f03aff7006 | ||
|  | 043b8a3105 | ||
|  | 1dd9984521 | ||
|  | d2be7f8c8f | ||
|  | 88dc202db2 | ||
|  | 083d54b008 | ||
|  | 87d77efa57 | ||
|  | 35c4a41d7b | ||
|  | 1ca3ca07d5 | ||
|  | d673846e3d | ||
|  | f62b7afede | ||
|  | e65770a53a | ||
|  | a92a741932 | ||
|  | 45f67191ba | ||
|  | 93f5da325b | ||
|  | 8fb955e182 | ||
|  | 9f5e6a4b37 | ||
|  | f43738446e | ||
|  | 923a46d304 | ||
|  | b9b5eaccae | ||
|  | cda11491c2 | ||
|  | 98c539f662 | ||
|  | 9fb958b302 | ||
|  | 8e25e76439 | ||
|  | 62694da7e6 | ||
|  | 86064651af | ||
|  | 65daaeb617 | ||
|  | 08b39f50b3 | ||
|  | d0f7e5ca4d | ||
|  | 4eb5058e68 | ||
|  | 1054193298 | ||
|  | 38c6cf0450 | ||
|  | 5b04b86867 | ||
|  | a074bcfd56 | ||
|  | f93179d946 | ||
|  | 2c347bc092 | ||
|  | 0f7119f468 | ||
|  | 2685a24705 | ||
|  | 371f72f4f1 | ||
|  | c70c00043b | ||
|  | 50d0a88276 | ||
|  | 5bbf576dae | ||
|  | 5d334e9619 | ||
|  | 98f9353338 | ||
|  | d3de7037e5 | ||
|  | 64431c6711 | ||
|  | d4ce193dc8 | ||
|  | 606305aec4 | ||
|  | a95f44d68b | ||
|  | ef2dc4b9e1 | ||
|  | 9baca1772b | ||
|  | 04cd19349d | ||
|  | 1280e5bc8b | ||
|  | dda90f956d | ||
|  | bc4b599513 | ||
|  | 090d52d678 | ||
|  | a47ad4842a | ||
|  | 3d5ed840dc | ||
|  | 11d75ff581 | ||
|  | 306fb7a3d1 | ||
|  | 0839b6f58e | ||
|  | fceca703b3 | ||
|  | 4dc60d2477 | ||
|  | d840d0b67d | ||
|  | 43dad4c465 | ||
|  | 60812b2d8a | ||
|  | 35e2caff13 | ||
|  | 1d9d5c6bc7 | ||
|  | 4d99536ea7 | ||
|  | 34537180c3 | ||
|  | cb01920ee6 | ||
|  | 437b01a0ff | ||
|  | 075a2abf71 | ||
|  | 985875cc75 | ||
|  | 1c45bc615f | ||
|  | fa7f2606fb | ||
|  | 12b95f1c72 | ||
|  | a0aee2021d | ||
|  | c90fd1e6d8 | ||
|  | 3b769fd2de | ||
|  | 71ecb89abc | ||
|  | 7b6bc1d3bc | ||
|  | 9c3be40fbe | ||
|  | ab87fa9ce4 | ||
|  | d1940a023a | ||
|  | 5a176a037c | ||
|  | ec25191c98 | ||
|  | 20b321f928 | ||
|  | 425b016d63 | ||
|  | b2c7189ce4 | ||
|  | f66886dbdb | ||
|  | 712f8b4680 | ||
|  | f626ee060a | ||
|  | 86aa7c97be | ||
|  | 30e3525987 | ||
|  | ad44f838da | ||
|  | 2569a35b6c | ||
|  | 1ee5e50d50 | ||
|  | 1dbec5eca8 | ||
|  | 2bc8db308c | ||
|  | f196740426 | ||
|  | 20121b79c5 | ||
|  | 741a4cfe53 | ||
|  | 0343de9f34 | ||
|  | 4772bca14a | ||
|  | 6ae1a5ba0d | ||
|  | 217c9718e4 | ||
|  | 61d7893467 | ||
|  | 8f26c01f4b | ||
|  | 61045ddd7f | ||
|  | 1bf72a0bc3 | ||
|  | 6d84b1bb8d | ||
|  | 8abd0b1fdf | ||
|  | 81e125b7ba | ||
|  | d5e1468718 | ||
|  | c232bf5ed6 | ||
|  | 21b25ffaee | ||
|  | ca0a93df08 | ||
|  | 699a22c757 | ||
|  | 8b2b1669b5 | ||
|  | c1e8370916 | ||
|  | ddedea8b90 | ||
|  | 8f414ce458 | ||
|  | 453f23da20 | ||
|  | 9e91e42a1b | ||
|  | b666734c79 | ||
|  | a2297f303d | ||
|  | ecde942255 | ||
|  | d668d43a0a | ||
|  | ca91a5dd95 | ||
|  | 5f9780d71c | ||
|  | ee37464741 | ||
|  | 8d73f927db | ||
|  | 4a0222bd1c | ||
|  | c0b8f5e3e1 | ||
|  | a9a0b263dc | ||
|  | f2b73187d8 | ||
|  | ef10ade0cc | ||
|  | 719bb4263e | ||
|  | b3602b268e | ||
|  | 66ec9bae27 | ||
|  | d96b6e77c0 | ||
|  | da64c018ac | ||
|  | f9fb97adf2 | ||
|  | 8316bc6480 | ||
|  | 08021e039a | ||
|  | cc6e0937a0 | ||
|  | c1d694a97c | ||
|  | fcf4f40c36 | ||
|  | 380b03399c | ||
|  | c33d02c53f | ||
|  | fa5e37993e | ||
|  | 437b2d506b | ||
|  | 4ed09f6431 | ||
|  | 0b98a6acf8 | ||
|  | 1d73c86cb2 | ||
|  | 40fe0f3239 | ||
|  | d1ea689999 | ||
|  | a6644ad5ff | ||
|  | 658746d2a3 | ||
|  | cbdd4de630 | ||
|  | 00c612485b | ||
|  | 3a6192bf73 | ||
|  | c64b5c2850 | ||
|  | fdbf079896 | ||
|  | d1a5395727 | ||
|  | 83a3642c0e | ||
|  | 9932d34304 | ||
|  | 7aa37a1976 | ||
|  | fa42fbdab8 | ||
|  | caa83ac830 | ||
|  | 3963fa9738 | ||
|  | 005a98d020 | ||
|  | 9560dc9408 | ||
|  | 4ac9a5edf0 | ||
|  | 37e62597ae | ||
|  | 90bfe378d0 | ||
|  | ce22b494ec | ||
|  | f9e0420647 | ||
|  | 2fe568d9ba | ||
|  | 2d4979df4d | ||
|  | b555b014b8 | ||
|  | 999b888c54 | ||
|  | 5193d7bddb | ||
|  | 6b03379e4e | ||
|  | 08d687ad60 | ||
|  | eb57089f06 | ||
|  | a76e4fede1 | ||
|  | 705d043540 | ||
|  | 5462e251f8 | ||
|  | 50788af6ca | ||
|  | 1a07c5a329 | ||
|  | 9fb81b2814 | ||
|  | 10ad7fbf6e | ||
|  | 811c4f2630 | ||
|  | f7e3b0a64f | ||
|  | 7d83d76fb3 | ||
|  | d3c41b38f7 | ||
|  | 57d6b16d5c | ||
|  | 27aa5ae7db | ||
|  | 62e8f564b9 | ||
|  | a1d7bb4208 | ||
|  | 5d8dae05c4 | ||
|  | 6bde07b5a0 | ||
|  | 846ab08661 | ||
|  | 999cf66b27 | ||
|  | 60539d890b | ||
|  | e5a0f25d94 | ||
|  | fde9d40098 | ||
|  | f70e9ea076 | ||
|  | d0af4aac4d | ||
|  | 7de3704210 | ||
|  | 1c33b837b8 | ||
|  | 95d20d7fba | ||
|  | 90b8806e7c | ||
|  | 39df80bf99 | ||
|  | bac4beae03 | ||
|  | a7b68c18b5 | ||
|  | ef2360baee | ||
|  | 8716e7e601 | ||
|  | 00c2dae969 | ||
|  | 8782bc5896 | ||
|  | 6359b90352 | ||
|  | 6cfa4976fe | ||
|  | 35cd7cf2b8 | ||
|  | b2d7f079b7 | ||
|  | 726069bc4b | ||
|  | fbccf01933 | ||
|  | c9f3c6f4a3 | ||
|  | c47da013ff | ||
|  | bc76499957 | ||
|  | 24afcff0ea | ||
|  | 6777f24845 | ||
|  | 61e0923fc4 | ||
|  | 757caeb9a4 | ||
|  | fe9dc6b272 | ||
|  | 24efdbe4da | ||
|  | 9ca102cf81 | ||
|  | 48df31d7b7 | ||
|  | 539afb1e1d | ||
|  | bdcba44ca5 | ||
|  | 99a51b07ac | ||
|  | 5fbaca75b4 | ||
|  | a6974371b0 | ||
|  | 409fa49234 | ||
|  | 9bbd6a70b8 | ||
|  | f0b4cb608a | ||
|  | 284d7e26d1 | ||
|  | 965c0937ac | ||
|  | d9cf6a4431 | ||
|  | e6ed8ee509 | ||
|  | 2563649b3e | ||
|  | 203bc41b06 | ||
|  | cb1d18c7c8 | ||
|  | 5ea68dafc4 | ||
|  | 68bb8252af | ||
|  | 406f742d29 | ||
|  | 5522e57f65 | ||
|  | 94e27dbfc5 | ||
|  | f5fc8f763f | ||
|  | 9058bf615c | ||
|  | 9d17137dec | ||
|  | 4a318553f7 | ||
|  | 0017074d38 | ||
|  | a39a26fcc2 | ||
|  | 2fe859b111 | ||
|  | c105b2df37 | ||
|  | 4fb86ab55a | ||
|  | 1ed98a5963 | ||
|  | a4a29ceb3c | ||
|  | 6249083431 | ||
|  | aa18c65fa8 | ||
|  | a7900940da | ||
|  | 008bc98070 | ||
|  | 0705589cc2 | ||
|  | b2caba593f | ||
|  | 6d4c64fcd5 | ||
|  | 7d41781fb4 | ||
|  | 0760facb77 | ||
|  | a0ce095807 | ||
|  | df0110913a | ||
|  | 06731374a4 | ||
|  | 6c8b7c0082 | ||
|  | 93136961b9 | ||
|  | 529a691e1d | ||
|  | 9f0b3eba47 | ||
|  | 6d897793cb | ||
|  | 0e12fc6b02 | ||
|  | c00558ea1b | ||
|  | bacf27a3ca | ||
|  | 6560ea0630 | ||
|  | 8338231ce5 | ||
|  | 5813a91244 | ||
|  | dfd8ab3545 | ||
|  | a5b9b949a8 | ||
|  | 72570e4510 | ||
|  | 3002aead6b | ||
|  | 841edbe6fb | ||
|  | 2b9aca0c56 | ||
|  | 3a17c3ee6d | ||
|  | df09252ee0 | ||
|  | f51778d417 | ||
|  | 119fc63794 | ||
|  | ee3425d3be | ||
|  | 31c979f30f | ||
|  | 89f2c26cd6 | ||
|  | 0dbf43d0aa | ||
|  | 8a6d11b191 | ||
|  | d8eb926e2c | ||
|  | 21d0adbdae | ||
|  | c5fd3a5753 | ||
|  | eae4e3d983 | ||
|  | bb1fe8daef | ||
|  | c5d8e09b41 | ||
|  | 369eae3d92 | ||
|  | e2fa457ca2 | ||
|  | 871f764e98 | ||
|  | f8853af902 | ||
|  | 4248d20f39 | ||
|  | 5cda08e7b0 | ||
|  | 7e9d96ee87 | ||
|  | 974ac31d33 | ||
|  | 0658b70631 | ||
|  | 53258eeede | ||
|  | 4f174308b9 | ||
|  | 98c9e40349 | ||
|  | 3a4756bd83 | ||
|  | 6ccb05cb2c | ||
|  | 3c2d32b867 | ||
|  | 956050434f | ||
|  | 38ab1550d2 | ||
|  | e852d1e57c | ||
|  | 7de0216976 | ||
|  | 911288e695 | ||
|  | 72e1f20383 | ||
|  | d28a6eaf9d | ||
|  | 17f3366556 | ||
|  | 0bef04ae0a | ||
|  | f11b906fd9 | ||
|  | 518358d9dc | ||
|  | 5ffde21d83 | ||
|  | 052302b3e7 | ||
|  | fe1ce21114 | ||
|  | ce5c9da107 | ||
|  | cf25b2866e | ||
|  | 07fd5a5f5f | ||
|  | 913fdac671 | ||
|  | 7dc838dea6 | ||
|  | 7112fd2a22 | ||
|  | 56e8c143dd | ||
|  | 7b4cbbe816 | ||
|  | 8f8ee4662d | ||
|  | 86013c7db4 | ||
|  | 01aa3324f8 | ||
|  | b9cfeee965 | ||
|  | b3684a70b5 | ||
|  | 51fce9343b | ||
|  | 0c5c3448d0 | ||
|  | deaef3ab86 | ||
|  | a443491c0c | ||
|  | 276d893198 | ||
|  | 653d0e71e4 | ||
|  | faa7d948a7 | ||
|  | 771342989e | ||
|  | e9ce519e4b | ||
|  | c016b102eb | ||
|  | 0583c60837 | ||
|  | 1c1a85dcef | ||
|  | c71e76335b | ||
|  | c1a32c4eb9 | ||
|  | 9ad1f769d3 | ||
|  | 87f8fd34b8 | ||
|  | e206d2919e | ||
|  | 9d809aa2ba | ||
|  | 8f744794e4 | ||
|  | 78ab4217be | ||
|  | d090df94c5 | ||
|  | 937f26da41 | ||
|  | 98e3ff014e | ||
|  | 6f84526364 | ||
|  | 105d38c885 | ||
|  | d7bdcd69fc | ||
|  | 87e537da90 | ||
|  | 8f16695f06 | ||
|  | 8403f6291f | ||
|  | 5af6ac3e80 | ||
|  | 0d557094b2 | ||
|  | a2aa78afd4 | ||
|  | b0de8abb63 | ||
|  | 6ff540ed08 | ||
|  | 2b8ed9850b | ||
|  | dcd579b5e3 | ||
|  | c9d2d301aa | ||
|  | 1aaef598a5 | ||
|  | 73d1f3d0e8 | ||
|  | e369ded6c5 | ||
|  | 269846c587 | ||
|  | 8dc98420db | ||
|  | 1014abe92f | ||
|  | 6927f10f8f | ||
|  | 49d3a7190a | ||
|  | a2e65b0018 | ||
|  | f48ee01a03 | ||
|  | 0e926c566b | ||
|  | d2c4c2c34c | ||
|  | c2253d1e25 | ||
|  | eae16b6e8c | ||
|  | 868ae5b5dd | ||
|  | 1406503e10 | ||
|  | 9ca9d88546 | ||
|  | 203d3f672c | ||
|  | 698b2688f6 | ||
|  | be1620dd07 | ||
|  | e1f0969957 | ||
|  | e1dd8cf2ab | ||
|  | 8ee90777ee | ||
|  | 2fe9c1e55f | ||
|  | 9dd7e2e43d | ||
|  | 5efbdf5d04 | ||
|  | 5be3472413 | ||
|  | a9a0953653 | ||
|  | d4ac4c44d0 | ||
|  | f459ff8ad0 | ||
|  | b96ea36b70 | ||
|  | e543cc0fed | ||
|  | 0b1b4df210 | ||
|  | e59ffb0b19 | ||
|  | 120c8f2c28 | ||
|  | fbfc5c8a2d | ||
|  | 31b018c80e | ||
|  | 255d708fb6 | ||
|  | 78d1da5fbc | ||
|  | 9c22a770ef | ||
|  | b201828236 | ||
|  | 2a8a885271 | ||
|  | 7adefd6ee0 | ||
|  | f967a5ecdc | ||
|  | c8d6dc2531 | ||
|  | 216b5fba7a | ||
|  | f4ec9a72d5 | ||
|  | cf0c2825eb | ||
|  | be46c419dc | ||
|  | 62c68d06fe | ||
|  | 4f4d8419bc | ||
|  | 16e17954b4 | ||
|  | cc1d080a5a | ||
|  | dd7f4f6752 | ||
|  | 9daeba02b5 | ||
|  | 8a96dbd121 | ||
|  | 2a57d0b6d0 | ||
|  | 8a5c1bade5 | ||
|  | fcc6943f98 | ||
|  | 72a9de058d | ||
|  | 8748be28b7 | ||
|  | 20bdea7ae0 | ||
|  | e19b8d35a9 | ||
|  | 81df74dfc8 | ||
|  | 153fa7478f | ||
|  | 500e9a4010 | ||
|  | 5352fc87ee | ||
|  | f07fd64ffb | ||
|  | 36f299c031 | ||
|  | 78cf310c58 | ||
|  | 18a3d71024 | ||
|  | 26db1048f9 | ||
|  | b61a250d58 | ||
|  | 1d10eba0cc | ||
|  | 35042132fa | ||
|  | 57c049b49f | ||
|  | 7a0ce0c957 | ||
|  | eb4cadb0b5 | ||
|  | ac0ca083c0 | ||
|  | 9afb4a9315 | ||
|  | df065e94b7 | ||
|  | a9789697e7 | ||
|  | 2d91be8814 | ||
|  | 5c58b0c2f4 | ||
|  | f0139f9808 | ||
|  | 5610a3184e | ||
|  | b202c73708 | ||
|  | dd4cec84bf | ||
|  | a1dac1e290 | ||
|  | e199d6725e | ||
|  | aef38b945d | ||
|  | cd5eac2cbb | ||
|  | 8fea443e71 | ||
|  | 2a47951e46 | ||
|  | 5234fda266 | ||
|  | e63067cd9f | ||
|  | be61cf6a88 | ||
|  | 5efc89d514 | ||
|  | 9c104faff3 | ||
|  | cf8fe16b09 | ||
|  | 71db193675 | ||
|  | 9952d9451e | ||
|  | fb738ad9fa | ||
|  | 46f2f752b0 | ||
|  | 42730b8fce | ||
|  | 1c2be579d9 | ||
|  | 51e891ff88 | ||
|  | 731efe1c01 | ||
|  | f77dd06e65 | ||
|  | af20f3df64 | ||
|  | 4078212089 | ||
|  | 7bdb3181e2 | ||
|  | 933608aec1 | ||
|  | 1d7f06bbba | ||
|  | f26cadab7f | ||
|  | eacf41a4f6 | ||
|  | ab3e64271b | ||
|  | e26ea14104 | ||
|  | 3967e23828 | ||
|  | 1f8c6f87c9 | ||
|  | f6203fe60a | ||
|  | 06bf710515 | ||
|  | 0f3cc3196c | ||
|  | 4403a00651 | ||
|  | 9c46feb22b | ||
|  | 10277aa956 | ||
|  | ff093d98c6 | ||
|  | acc0e0875b | ||
|  | 69f85bd688 | ||
|  | 910d983b82 | ||
|  | 128415bc9e | ||
|  | 082ce798d8 | ||
|  | 234abd82a2 | ||
|  | 3cbc1bbb1b | ||
|  | 0ed9f6cc4f | ||
|  | 10b092a9a7 | ||
|  | 444a897410 | ||
|  | e013afb053 | ||
|  | 34364f5627 | ||
|  | cef378d820 | ||
|  | a27353c166 | ||
|  | bbd197c71d | ||
|  | fabf013714 | ||
|  | 81dcfecb4e | ||
|  | 971a62ebc9 | ||
|  | 04f2c92ba6 | ||
|  | 00d0f8cfc7 | ||
|  | c5c404ea05 | ||
|  | c80a44933c | ||
|  | 5599b999ec | ||
|  | 172cbdaa84 | ||
|  | bf1cd457cd | ||
|  | 8af50a51ba | ||
|  | ddf31e87b2 | ||
|  | 5adbc012f3 | 
							
								
								
									
										32
									
								
								.github/ISSUE_TEMPLATE.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,32 @@ | ||||
| <!-- | ||||
| ## Before you hit that Submit button.... | ||||
|  | ||||
| This issue tracker is for problems with the Node-RED runtime, the editor or the core nodes. | ||||
|  | ||||
| If your issue is: | ||||
|   - a general 'how-to' type question, | ||||
|   - a feature request or suggestion for a change, | ||||
|   - or problems with 3rd party (`node-red-contrib-`) nodes | ||||
|  | ||||
| please use the [mailing list](https://groups.google.com/forum/#!forum/node-red), [slack team](https://nodered.org/slack) or ask a question on [Stack Overflow](https://stackoverflow.com/questions/tagged/node-red) and tag it `node-red`. | ||||
|  | ||||
| That way the whole Node-RED user community can help, rather than rely on the core development team. | ||||
|  | ||||
| ## So you have a real issue to raise... | ||||
|  | ||||
| To help us understand the issue, please fill-in as much of the following information as you can: | ||||
| --> | ||||
|  | ||||
| ### What are the steps to reproduce? | ||||
|  | ||||
| ### What happens? | ||||
|  | ||||
| ### What do you expect to happen? | ||||
|  | ||||
| ### Please tell us about your environment: | ||||
|  | ||||
| - [ ] Node-RED version: | ||||
| - [ ] node.js version: | ||||
| - [ ] npm version: | ||||
| - [ ] Platform/OS: | ||||
| - [ ] Browser: | ||||
							
								
								
									
										34
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | ||||
| <!-- | ||||
| ## Before you hit that Submit button.... | ||||
|  | ||||
| Please read our [contribution guidelines](https://github.com/node-red/node-red/blob/master/CONTRIBUTING.md) | ||||
| before submitting a pull-request. | ||||
|  | ||||
| ## Types of changes | ||||
|  | ||||
| What types of changes does your code introduce? | ||||
| Put an `x` in the boxes that apply | ||||
| --> | ||||
|  | ||||
| - [ ] Bugfix (non-breaking change which fixes an issue) | ||||
| - [ ] New feature (non-breaking change which adds functionality) | ||||
|  | ||||
| <!-- | ||||
| If you want to raise a pull-request with a new feature, or a refactoring | ||||
| of existing code, it **may well get rejected** if it hasn't been discussed on | ||||
| the [mailing list](https://groups.google.com/forum/#!forum/node-red) or | ||||
| [slack team](https://nodered.org/slack) first. | ||||
|  | ||||
| --> | ||||
|  | ||||
| ## Proposed changes | ||||
|  | ||||
| <!-- Describe the nature of this change. What problem does it address? --> | ||||
|  | ||||
| ## Checklist | ||||
| <!-- Put an `x` in the boxes that apply --> | ||||
|  | ||||
| - [ ] I have read the [contribution guidelines](https://github.com/node-red/node-red/blob/master/CONTRIBUTING.md) | ||||
| - [ ] For non-bugfix PRs, I have discussed this change on the mailing list/slack team. | ||||
| - [ ] I have run `grunt` to verify the unit tests pass | ||||
| - [ ] I have added suitable unit tests to cover the new/changed functionality | ||||
							
								
								
									
										24
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,11 +1,19 @@ | ||||
| node_modules | ||||
| credentials.json | ||||
| flows*.json | ||||
| .DS_store | ||||
| .config.json | ||||
| .dist | ||||
| .jshintignore | ||||
| .npm | ||||
| .project | ||||
| .sessions.json | ||||
| .settings | ||||
| .tern-project | ||||
| *.backup | ||||
| *_cred* | ||||
| coverage | ||||
| credentials.json | ||||
| flows*.json | ||||
| nodes/node-red-nodes/ | ||||
| .npm | ||||
| /coverage | ||||
| .config.json | ||||
| .sessions.json | ||||
|  | ||||
| node_modules | ||||
| public | ||||
| locales/zz-ZZ | ||||
| nodes/core/locales/zz-ZZ | ||||
|   | ||||
							
								
								
									
										19
									
								
								.jshintrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,19 @@ | ||||
| { | ||||
|     "asi": true,        // allow missing semicolons | ||||
|     "curly": true,      // require braces | ||||
|     "eqnull": true,     // ignore ==null | ||||
|     //"eqeqeq": true,   // enforce === | ||||
|     "freeze": true,     // don't allow override | ||||
|     "indent": 4,        // default indent of 4 | ||||
|     "forin": true,      // require property filtering in "for in" loops | ||||
|     "immed": true,      // require immediate functions to be wrapped in ( ) | ||||
|     "nonbsp": true,     // warn on unexpected whitespace breaking chars | ||||
|     //"strict": true,   // commented out for now as it causes 100s of warnings, but want to get there eventually | ||||
|     //"unused": true,   // Check for unused functions and variables | ||||
|     "loopfunc": true,   // allow functions to be defined in loops | ||||
|     //"expr": true,     // allow ternery operator syntax... | ||||
|     "shadow": true,     // allow variable shadowing (re-use of names...) | ||||
|     "sub": true,        // don't warn that foo['bar'] should be written as foo.bar | ||||
|     "proto": true,      // allow setting of __proto__ in node < v0.12, | ||||
|     "esversion": 6      // allow es6 | ||||
| } | ||||
| @@ -1,4 +1,5 @@ | ||||
| .git/* | ||||
| *.json | ||||
| lib/* | ||||
| /Gruntfile.js | ||||
| /.git/* | ||||
| /lib/* | ||||
| *.backup | ||||
| /public/* | ||||
|   | ||||
							
								
								
									
										7
									
								
								.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| .settings | ||||
| .jshintignore | ||||
| .jshintrc | ||||
| .project | ||||
| .tern-project | ||||
| .travis.yml | ||||
| .git | ||||
							
								
								
									
										21
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						| @@ -1,11 +1,12 @@ | ||||
| sudo: false | ||||
| language: node_js | ||||
| before_install: | ||||
|   - npm install -g npm@~1.4.18 | ||||
| node_js: | ||||
|   - "0.10" | ||||
|   - "0.8" | ||||
| script: | ||||
|   - istanbul cover ./node_modules/.bin/grunt --report lcovonly && istanbul report text && ( cat coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js || true ) && rm -rf coverage | ||||
| before_script: | ||||
|   - npm install -g istanbul | ||||
|   - npm install coveralls | ||||
| matrix: | ||||
|   include: | ||||
|     - node_js: "10" | ||||
|       script: | ||||
|         - istanbul cover ./node_modules/.bin/grunt --report lcovonly && istanbul report text && ( cat coverage/lcov.info | $(npm get prefix)/bin/coveralls || true ) && rm -rf coverage | ||||
|       before_script: | ||||
|         - npm install -g istanbul coveralls | ||||
|     - node_js: "8" | ||||
|     - node_js: "6" | ||||
|     - node_js: "4" | ||||
|   | ||||
							
								
								
									
										1194
									
								
								CHANGELOG.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										74
									
								
								CODE_OF_CONDUCT.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,74 @@ | ||||
| # Contributor Covenant Code of Conduct | ||||
|  | ||||
| ## Our Pledge | ||||
|  | ||||
| In the interest of fostering an open and welcoming environment, we as | ||||
| contributors and maintainers pledge to making participation in our project and | ||||
| our community a harassment-free experience for everyone, regardless of age, body | ||||
| size, disability, ethnicity, gender identity and expression, level of experience, | ||||
| nationality, personal appearance, race, religion, or sexual identity and | ||||
| orientation. | ||||
|  | ||||
| ## Our Standards | ||||
|  | ||||
| Examples of behavior that contributes to creating a positive environment | ||||
| include: | ||||
|  | ||||
| * Using welcoming and inclusive language | ||||
| * Being respectful of differing viewpoints and experiences | ||||
| * Gracefully accepting constructive criticism | ||||
| * Focusing on what is best for the community | ||||
| * Showing empathy towards other community members | ||||
|  | ||||
| Examples of unacceptable behavior by participants include: | ||||
|  | ||||
| * The use of sexualized language or imagery and unwelcome sexual attention or | ||||
| advances | ||||
| * Trolling, insulting/derogatory comments, and personal or political attacks | ||||
| * Public or private harassment | ||||
| * Publishing others' private information, such as a physical or electronic | ||||
|   address, without explicit permission | ||||
| * Other conduct which could reasonably be considered inappropriate in a | ||||
|   professional setting | ||||
|  | ||||
| ## Our Responsibilities | ||||
|  | ||||
| Project maintainers are responsible for clarifying the standards of acceptable | ||||
| behavior and are expected to take appropriate and fair corrective action in | ||||
| response to any instances of unacceptable behavior. | ||||
|  | ||||
| Project maintainers have the right and responsibility to remove, edit, or | ||||
| reject comments, commits, code, wiki edits, issues, and other contributions | ||||
| that are not aligned to this Code of Conduct, or to ban temporarily or | ||||
| permanently any contributor for other behaviors that they deem inappropriate, | ||||
| threatening, offensive, or harmful. | ||||
|  | ||||
| ## Scope | ||||
|  | ||||
| This Code of Conduct applies both within project spaces and in public spaces | ||||
| when an individual is representing the project or its community. Examples of | ||||
| representing a project or community include using an official project e-mail | ||||
| address, posting via an official social media account, or acting as an appointed | ||||
| representative at an online or offline event. Representation of a project may be | ||||
| further defined and clarified by project maintainers. | ||||
|  | ||||
| ## Enforcement | ||||
|  | ||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||
| reported by contacting the project team at team@nodered.org. All | ||||
| complaints will be reviewed and investigated and will result in a response that | ||||
| is deemed necessary and appropriate to the circumstances. The project team is | ||||
| obligated to maintain confidentiality with regard to the reporter of an incident. | ||||
| Further details of specific enforcement policies may be posted separately. | ||||
|  | ||||
| Project maintainers who do not follow or enforce the Code of Conduct in good | ||||
| faith may face temporary or permanent repercussions as determined by other | ||||
| members of the project's leadership. | ||||
|  | ||||
| ## Attribution | ||||
|  | ||||
| This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, | ||||
| available at [http://contributor-covenant.org/version/1/4][version] | ||||
|  | ||||
| [homepage]: http://contributor-covenant.org | ||||
| [version]: http://contributor-covenant.org/version/1/4/ | ||||
| @@ -6,11 +6,14 @@ We welcome contributions, but request you follow these guidelines. | ||||
|  - [Feature requests](#feature-requests) | ||||
|  - [Pull-Requests](#pull-requests) | ||||
|    - [Contributor License Agreement](#contributor-license-agreement) | ||||
|   | ||||
|  | ||||
| This project adheres to the [Contributor Covenant 1.4](http://contributor-covenant.org/version/1/4/). | ||||
| By participating, you are expected to uphold this code. Please report unacceptable | ||||
| behavior to the project's core team at team@nodered.org. | ||||
|  | ||||
| ## Raising issues | ||||
|  | ||||
| Please raise any bug reports on the project's  | ||||
| [issue tracker](https://github.com/node-red/node-red/issues?state=open). Be sure to | ||||
| Please raise any bug reports on the relevant project's issue tracker. Be sure to | ||||
| search the list to see if your issue has already been raised. | ||||
|  | ||||
| A good bug report is one that make it easy for us to understand what you were | ||||
| @@ -25,7 +28,6 @@ At a minimum, please include: | ||||
|  - Version of Node-RED - either release number if you downloaded a zip, or the first few lines of `git log` if you are cloning the repository directly. | ||||
|  - Version of node.js - what does `node -v` say? | ||||
|  | ||||
|  | ||||
| ## Feature requests | ||||
|  | ||||
| For feature requests, please raise them on the [mailing list](https://groups.google.com/forum/#!forum/node-red). | ||||
| @@ -33,24 +35,16 @@ For feature requests, please raise them on the [mailing list](https://groups.goo | ||||
| ## Pull-Requests | ||||
|  | ||||
| If you want to raise a pull-request with a new feature, or a refactoring | ||||
| of existing code, it may well get rejected if you haven't discussed it on  | ||||
| of existing code, it may well get rejected if you haven't discussed it on | ||||
| the [mailing list](https://groups.google.com/forum/#!forum/node-red) first. | ||||
|  | ||||
| ### Contributor License Agreement | ||||
| All contributors need to sign the JS Foundation's Contributor License Agreement. | ||||
| It is an online process and quick to do. You can read the details of the agreement | ||||
| here: https://cla.js.foundation/node-red/node-red. | ||||
|  | ||||
| In order for us to accept pull-requests, the contributor must first complete | ||||
| a Contributor License Agreement (CLA). This clarifies the intellectual  | ||||
| property license granted with any contribution. It is for your protection as a  | ||||
| Contributor as well as the protection of IBM and its customers; it does not  | ||||
| change your rights to use your own Contributions for any other purpose. | ||||
| If you raise a pull-request without having signed the CLA, you will be prompted | ||||
| to do so automatically. | ||||
|  | ||||
| You can download the CLAs here: | ||||
|  | ||||
|  - [individual](http://nodered.org/cla/node-red-cla-individual.pdf) | ||||
|  - [corporate](http://nodered.org/cla/node-red-cla-corporate.pdf) | ||||
|  | ||||
| If you are an IBMer, please contact us directly as the contribution process is | ||||
| slightly different. | ||||
|  | ||||
| ### Coding standards | ||||
|  | ||||
| @@ -59,13 +53,5 @@ code base. Some basic rules include: | ||||
|  | ||||
|  - all files must have the Apache license in the header. | ||||
|  - indent with 4-spaces, no tabs. No arguments. | ||||
|  - opening brace on same line as `if`/`for`/`function`/etc, closing brace on its | ||||
|    own line. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  - opening brace on same line as `if`/`for`/`function` and so on, closing brace | ||||
|  on its own line. | ||||
|   | ||||
							
								
								
									
										559
									
								
								Gruntfile.js
									
									
									
									
									
								
							
							
						
						| @@ -1,5 +1,5 @@ | ||||
| /** | ||||
|  * Copyright 2013, 2014 IBM Corp. | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
| @@ -14,82 +14,497 @@ | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
| var path = require("path"); | ||||
|  | ||||
| module.exports = function(grunt) { | ||||
|      | ||||
|     // Project configuration. | ||||
|  | ||||
|     var nodemonArgs = ["-v"]; | ||||
|     var flowFile = grunt.option('flowFile'); | ||||
|     if (flowFile) { | ||||
|         nodemonArgs.push(flowFile); | ||||
|     } | ||||
|  | ||||
|     grunt.initConfig({ | ||||
|             pkg: grunt.file.readJSON('package.json'), | ||||
|             simplemocha: { | ||||
|                 options: { | ||||
|                     globals: ['expect'], | ||||
|                     timeout: 3000, | ||||
|                     ignoreLeaks: false, | ||||
|                     ui: 'bdd', | ||||
|                     reporter: 'spec' | ||||
|                 }, | ||||
|                 all: { src: ['test/**/*_spec.js'] }, | ||||
|                 core: { src: ["test/_spec.js","test/red/**/*_spec.js"]}, | ||||
|                 nodes: { src: ["test/nodes/**/*_spec.js"]} | ||||
|         pkg: grunt.file.readJSON('package.json'), | ||||
|         paths: { | ||||
|             dist: ".dist" | ||||
|         }, | ||||
|         simplemocha: { | ||||
|             options: { | ||||
|                 globals: ['expect'], | ||||
|                 timeout: 3000, | ||||
|                 ignoreLeaks: false, | ||||
|                 ui: 'bdd', | ||||
|                 reporter: 'spec' | ||||
|             }, | ||||
|             jshint: { | ||||
|                 options: { | ||||
|                     // http://www.jshint.com/docs/options/ | ||||
|                     "asi": true,      // allow missing semicolons | ||||
|                     "curly": true,    // require braces | ||||
|                     "eqnull": true,   // ignore ==null | ||||
|                     "forin": true,    // require property filtering in "for in" loops | ||||
|                     "immed": true,    // require immediate functions to be wrapped in ( ) | ||||
|                     "nonbsp": true,   // warn on unexpected whitespace breaking chars | ||||
|                     //"strict": true, // commented out for now as it causes 100s of warnings, but want to get there eventually | ||||
|                     "loopfunc": true, // allow functions to be defined in loops | ||||
|                     "sub": true       // don't warn that foo['bar'] should be written as foo.bar | ||||
|                 }, | ||||
|                 all: [ | ||||
|                     'Gruntfile.js', | ||||
|                     'red.js', | ||||
|                     'red/**/*.js', | ||||
|                     'nodes/**/*.js', | ||||
|                     'public/red/**/*.js' | ||||
|                 ], | ||||
|                  | ||||
|                 core: { | ||||
|                     files: { | ||||
|                         src: [ | ||||
|                             'Gruntfile.js', | ||||
|                             'red.js', | ||||
|                             'red/**/*.js' | ||||
|                         ] | ||||
|                     } | ||||
|                 }, | ||||
|                 nodes: { | ||||
|                     files: { | ||||
|                         src: [ 'nodes/**/*.js' ] | ||||
|                     } | ||||
|                 }, | ||||
|                 editor: { | ||||
|                     files: { | ||||
|                         src: [ 'public/red/**/*.js' ] | ||||
|                     } | ||||
|                 }, | ||||
|                 tests: { | ||||
|                     files: { | ||||
|                         src: ['test/**/*.js'] | ||||
|                     }, | ||||
|                     options: { | ||||
|                         "expr": true | ||||
|                     } | ||||
|                 } | ||||
|                  | ||||
|             all: { src: ['test/**/*_spec.js'] }, | ||||
|             core: { src: ["test/_spec.js","test/red/**/*_spec.js"]}, | ||||
|             nodes: { src: ["test/nodes/**/*_spec.js"]} | ||||
|         }, | ||||
|         webdriver: { | ||||
|             all: { | ||||
|                 configFile: 'test/editor/wdio.conf.js' | ||||
|             } | ||||
|         }, | ||||
|         mocha_istanbul: { | ||||
|             options: { | ||||
|                 globals: ['expect'], | ||||
|                 timeout: 3000, | ||||
|                 ignoreLeaks: false, | ||||
|                 ui: 'bdd', | ||||
|                 reportFormats: ['lcov','html'], | ||||
|                 print: 'both' | ||||
|             }, | ||||
|             all: { src: ['test/**/*_spec.js'] }, | ||||
|             core: { src: ["test/_spec.js","test/red/**/*_spec.js"]}, | ||||
|             nodes: { src: ["test/nodes/**/*_spec.js"]} | ||||
|         }, | ||||
|         jshint: { | ||||
|             options: { | ||||
|                 jshintrc:true | ||||
|                 // http://www.jshint.com/docs/options/ | ||||
|                 //"asi": true,      // allow missing semicolons | ||||
|                 //"curly": true,    // require braces | ||||
|                 //"eqnull": true,   // ignore ==null | ||||
|                 //"forin": true,    // require property filtering in "for in" loops | ||||
|                 //"immed": true,    // require immediate functions to be wrapped in ( ) | ||||
|                 //"nonbsp": true,   // warn on unexpected whitespace breaking chars | ||||
|                 ////"strict": true, // commented out for now as it causes 100s of warnings, but want to get there eventually | ||||
|                 //"loopfunc": true, // allow functions to be defined in loops | ||||
|                 //"sub": true       // don't warn that foo['bar'] should be written as foo.bar | ||||
|             }, | ||||
|             all: [ | ||||
|                 'Gruntfile.js', | ||||
|                 'red.js', | ||||
|                 'red/**/*.js', | ||||
|                 'nodes/core/*/*.js', | ||||
|                 'editor/js/**/*.js' | ||||
|             ], | ||||
|             core: { | ||||
|                 files: { | ||||
|                     src: [ | ||||
|                         'Gruntfile.js', | ||||
|                         'red.js', | ||||
|                         'red/**/*.js' | ||||
|                     ] | ||||
|                 } | ||||
|             }, | ||||
|             nodes: { | ||||
|                 files: { | ||||
|                     src: [ 'nodes/core/*/*.js' ] | ||||
|                 } | ||||
|             }, | ||||
|             editor: { | ||||
|                 files: { | ||||
|                     src: [ 'editor/js/**/*.js' ] | ||||
|                 } | ||||
|             }, | ||||
|             tests: { | ||||
|                 files: { | ||||
|                     src: ['test/**/*.js'] | ||||
|                 }, | ||||
|                 options: { | ||||
|                     "expr": true | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         concat: { | ||||
|             options: { | ||||
|                 separator: ";", | ||||
|             }, | ||||
|             build: { | ||||
|                 src: [ | ||||
|                     // Ensure editor source files are concatenated in | ||||
|                     // the right order | ||||
|                     "editor/js/red.js", | ||||
|                     "editor/js/events.js", | ||||
|                     "editor/js/i18n.js", | ||||
|                     "editor/js/settings.js", | ||||
|                     "editor/js/user.js", | ||||
|                     "editor/js/comms.js", | ||||
|                     "editor/js/text/bidi.js", | ||||
|                     "editor/js/text/format.js", | ||||
|                     "editor/js/ui/state.js", | ||||
|                     "editor/js/nodes.js", | ||||
|                     "editor/js/history.js", | ||||
|                     "editor/js/validators.js", | ||||
|                     "editor/js/ui/utils.js", | ||||
|                     "editor/js/ui/common/editableList.js", | ||||
|                     "editor/js/ui/common/checkboxSet.js", | ||||
|                     "editor/js/ui/common/menu.js", | ||||
|                     "editor/js/ui/common/panels.js", | ||||
|                     "editor/js/ui/common/popover.js", | ||||
|                     "editor/js/ui/common/searchBox.js", | ||||
|                     "editor/js/ui/common/tabs.js", | ||||
|                     "editor/js/ui/common/stack.js", | ||||
|                     "editor/js/ui/common/typedInput.js", | ||||
|                     "editor/js/ui/actions.js", | ||||
|                     "editor/js/ui/deploy.js", | ||||
|                     "editor/js/ui/diff.js", | ||||
|                     "editor/js/ui/keyboard.js", | ||||
|                     "editor/js/ui/workspaces.js", | ||||
|                     "editor/js/ui/view.js", | ||||
|                     "editor/js/ui/sidebar.js", | ||||
|                     "editor/js/ui/palette.js", | ||||
|                     "editor/js/ui/tab-info.js", | ||||
|                     "editor/js/ui/tab-config.js", | ||||
|                     "editor/js/ui/palette-editor.js", | ||||
|                     "editor/js/ui/editor.js", | ||||
|                     "editor/js/ui/tray.js", | ||||
|                     "editor/js/ui/clipboard.js", | ||||
|                     "editor/js/ui/library.js", | ||||
|                     "editor/js/ui/notifications.js", | ||||
|                     "editor/js/ui/search.js", | ||||
|                     "editor/js/ui/typeSearch.js", | ||||
|                     "editor/js/ui/subflow.js", | ||||
|                     "editor/js/ui/userSettings.js", | ||||
|                     "editor/js/ui/projects/projects.js", | ||||
|                     "editor/js/ui/projects/projectSettings.js", | ||||
|                     "editor/js/ui/projects/projectUserSettings.js", | ||||
|                     "editor/js/ui/projects/tab-versionControl.js", | ||||
|                     "editor/js/ui/touch/radialMenu.js" | ||||
|                 ], | ||||
|                 dest: "public/red/red.js" | ||||
|             }, | ||||
|             vendor: { | ||||
|                 files: { | ||||
|                     "public/vendor/vendor.js": [ | ||||
|                         "editor/vendor/jquery/js/jquery-1.11.3.min.js", | ||||
|                         "editor/vendor/bootstrap/js/bootstrap.min.js", | ||||
|                         "editor/vendor/jquery/js/jquery-ui-1.10.3.custom.min.js", | ||||
|                         "editor/vendor/jquery/js/jquery.ui.touch-punch.min.js", | ||||
|                         "editor/vendor/marked/marked.min.js", | ||||
|                         "editor/vendor/d3/d3.v3.min.js", | ||||
|                         "editor/vendor/i18next/i18next.min.js" | ||||
|                     ], | ||||
|                     "public/vendor/vendor.css": [ | ||||
|                         // TODO: resolve relative resource paths in | ||||
|                         //       bootstrap/FA/jquery | ||||
|                     ], | ||||
|                     "public/vendor/jsonata/jsonata.min.js": [ | ||||
|                         "node_modules/jsonata/jsonata-es5.min.js", | ||||
|                         "editor/vendor/jsonata/formatter.js" | ||||
|                     ], | ||||
|                     "public/vendor/ace/worker-jsonata.js": [ | ||||
|                         "node_modules/jsonata/jsonata-es5.min.js", | ||||
|                         "editor/vendor/jsonata/worker-jsonata.js" | ||||
|                     ] | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         uglify: { | ||||
|             build: { | ||||
|                 files: { | ||||
|                     'public/red/red.min.js': 'public/red/red.js', | ||||
|                     'public/red/main.min.js': 'public/red/main.js', | ||||
|                     'public/vendor/ace/mode-jsonata.js': 'editor/vendor/jsonata/mode-jsonata.js', | ||||
|                     'public/vendor/ace/snippets/jsonata.js': 'editor/vendor/jsonata/snippets-jsonata.js' | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         sass: { | ||||
|             build: { | ||||
|                 options: { | ||||
|                     outputStyle: 'compressed' | ||||
|                 }, | ||||
|                 files: [{ | ||||
|                     dest: 'public/red/style.min.css', | ||||
|                     src: 'editor/sass/style.scss' | ||||
|                 }, | ||||
|                 { | ||||
|                     dest: 'public/vendor/bootstrap/css/bootstrap.min.css', | ||||
|                     src: 'editor/vendor/bootstrap/css/bootstrap.css' | ||||
|                 }] | ||||
|             } | ||||
|         }, | ||||
|         jsonlint: { | ||||
|             messages: { | ||||
|                 src: [ | ||||
|                     'nodes/core/locales/en-US/messages.json', | ||||
|                     'red/api/locales/en-US/editor.json', | ||||
|                     'red/runtime/locales/en-US/runtime.json' | ||||
|                 ] | ||||
|             }, | ||||
|             keymaps: { | ||||
|                 src: [ | ||||
|                     'editor/js/keymap.json' | ||||
|                 ] | ||||
|             } | ||||
|         }, | ||||
|         attachCopyright: { | ||||
|             js: { | ||||
|                 src: [ | ||||
|                     'public/red/red.min.js', | ||||
|                     'public/red/main.min.js' | ||||
|                 ] | ||||
|             }, | ||||
|             css: { | ||||
|                 src: [ | ||||
|                     'public/red/style.min.css' | ||||
|                 ] | ||||
|             } | ||||
|         }, | ||||
|         clean: { | ||||
|             build: { | ||||
|                 src: [ | ||||
|                     "public/red", | ||||
|                     "public/index.html", | ||||
|                     "public/favicon.ico", | ||||
|                     "public/icons", | ||||
|                     "public/vendor" | ||||
|                 ] | ||||
|             }, | ||||
|             release: { | ||||
|                 src: [ | ||||
|                     '<%= paths.dist %>' | ||||
|                 ] | ||||
|             } | ||||
|         }, | ||||
|         watch: { | ||||
|             js: { | ||||
|                 files: [ | ||||
|                     'editor/js/**/*.js' | ||||
|                 ], | ||||
|                 tasks: ['copy:build','concat','uglify','attachCopyright:js'] | ||||
|             }, | ||||
|             sass: { | ||||
|                 files: [ | ||||
|                     'editor/sass/**/*.scss' | ||||
|                 ], | ||||
|                 tasks: ['sass','attachCopyright:css'] | ||||
|             }, | ||||
|             json: { | ||||
|                 files: [ | ||||
|                     'nodes/core/locales/en-US/messages.json', | ||||
|                     'red/api/locales/en-US/editor.json', | ||||
|                     'red/runtime/locales/en-US/runtime.json' | ||||
|                 ], | ||||
|                 tasks: ['jsonlint:messages'] | ||||
|             }, | ||||
|             keymaps: { | ||||
|                 files: [ | ||||
|                     'editor/js/keymap.json' | ||||
|                 ], | ||||
|                 tasks: ['jsonlint:keymaps','copy:build'] | ||||
|             }, | ||||
|             misc: { | ||||
|                 files: [ | ||||
|                     'CHANGELOG.md' | ||||
|                 ], | ||||
|                 tasks: ['copy:build'] | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         nodemon: { | ||||
|             /* uses .nodemonignore */ | ||||
|             dev: { | ||||
|                 script: 'red.js', | ||||
|                 options: { | ||||
|                     args: nodemonArgs, | ||||
|                     ext: 'js,html,json', | ||||
|                     watch: [ | ||||
|                         'red','nodes' | ||||
|                     ] | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         concurrent: { | ||||
|             dev: { | ||||
|                 tasks: ['nodemon', 'watch'], | ||||
|                 options: { | ||||
|                     logConcurrentOutput: true | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|  | ||||
|         copy: { | ||||
|             build: { | ||||
|                 files:[ | ||||
|                     { | ||||
|                         src: 'editor/js/main.js', | ||||
|                         dest: 'public/red/main.js' | ||||
|                     }, | ||||
|                     { | ||||
|                         src: 'editor/js/keymap.json', | ||||
|                         dest: 'public/red/keymap.json' | ||||
|                     }, | ||||
|                     { | ||||
|                         cwd: 'editor/images', | ||||
|                         src: '**', | ||||
|                         expand: true, | ||||
|                         dest: 'public/red/images/' | ||||
|                     }, | ||||
|                     { | ||||
|                         cwd: 'editor/vendor', | ||||
|                         src: [ | ||||
|                             'ace/**', | ||||
|                             //'bootstrap/css/**', | ||||
|                             'bootstrap/img/**', | ||||
|                             'jquery/css/**', | ||||
|                             'font-awesome/**' | ||||
|                         ], | ||||
|                         expand: true, | ||||
|                         dest: 'public/vendor/' | ||||
|                     }, | ||||
|                     { | ||||
|                         cwd: 'editor/icons', | ||||
|                         src: '**', | ||||
|                         expand: true, | ||||
|                         dest: 'public/icons/' | ||||
|                     }, | ||||
|                     { | ||||
|                         expand: true, | ||||
|                         src: ['editor/index.html','editor/favicon.ico'], | ||||
|                         dest: 'public/', | ||||
|                         flatten: true | ||||
|                     }, | ||||
|                     { | ||||
|                         src: 'CHANGELOG.md', | ||||
|                         dest: 'public/red/about' | ||||
|                     } | ||||
|                 ] | ||||
|             }, | ||||
|             release: { | ||||
|                 files: [{ | ||||
|                     mode: true, | ||||
|                     expand: true, | ||||
|                     src: [ | ||||
|                         '*.md', | ||||
|                         'LICENSE', | ||||
|                         'package.json', | ||||
|                         'settings.js', | ||||
|                         'red.js', | ||||
|                         'lib/.gitignore', | ||||
|                         'nodes/*.demo', | ||||
|                         'nodes/core/**', | ||||
|                         'red/**', | ||||
|                         'public/**', | ||||
|                         'editor/templates/**', | ||||
|                         'bin/**' | ||||
|                     ], | ||||
|                     dest: path.resolve('<%= paths.dist %>/node-red-<%= pkg.version %>') | ||||
|                 }] | ||||
|             } | ||||
|         }, | ||||
|         chmod: { | ||||
|             options: { | ||||
|                 mode: '755' | ||||
|             }, | ||||
|             release: { | ||||
|                 src: [ | ||||
|                     path.resolve('<%= paths.dist %>/node-red-<%= pkg.version %>/nodes/core/hardware/nrgpio*'), | ||||
|                     path.resolve('<%= paths.dist %>/node-red-<%= pkg.version %>/red/runtime/storage/localfilesystem/projects/git/node-red-*sh') | ||||
|                 ] | ||||
|             } | ||||
|         }, | ||||
|         compress: { | ||||
|             release: { | ||||
|                 options: { | ||||
|                     archive: '<%= paths.dist %>/node-red-<%= pkg.version %>.zip' | ||||
|                 }, | ||||
|                 expand: true, | ||||
|                 cwd: '<%= paths.dist %>/', | ||||
|                 src: ['node-red-<%= pkg.version %>/**'] | ||||
|             } | ||||
|         } | ||||
|     }); | ||||
|      | ||||
|  | ||||
|     grunt.loadNpmTasks('grunt-simple-mocha'); | ||||
|     grunt.loadNpmTasks('grunt-contrib-jshint'); | ||||
|      | ||||
|     grunt.registerTask('default', ['test-core','test-editor','test-nodes']); | ||||
|      | ||||
|     grunt.registerTask('test-core', ['jshint:core','simplemocha:core']); | ||||
|     grunt.registerTask('test-editor', ['jshint:editor']); | ||||
|     grunt.registerTask('test-nodes', ['simplemocha:nodes']); | ||||
|      | ||||
|     grunt.loadNpmTasks('grunt-contrib-concat'); | ||||
|     grunt.loadNpmTasks('grunt-contrib-uglify'); | ||||
|     grunt.loadNpmTasks('grunt-contrib-clean'); | ||||
|     grunt.loadNpmTasks('grunt-contrib-watch'); | ||||
|     grunt.loadNpmTasks('grunt-concurrent'); | ||||
|     grunt.loadNpmTasks('grunt-sass'); | ||||
|     grunt.loadNpmTasks('grunt-nodemon'); | ||||
|     grunt.loadNpmTasks('grunt-contrib-compress'); | ||||
|     grunt.loadNpmTasks('grunt-contrib-copy'); | ||||
|     grunt.loadNpmTasks('grunt-chmod'); | ||||
|     grunt.loadNpmTasks('grunt-jsonlint'); | ||||
|     grunt.loadNpmTasks('grunt-mocha-istanbul'); | ||||
|     grunt.loadNpmTasks('grunt-webdriver'); | ||||
|  | ||||
|     grunt.registerMultiTask('attachCopyright', function() { | ||||
|         var files = this.data.src; | ||||
|         var copyright = "/**\n"+ | ||||
|             " * Copyright JS Foundation and other contributors, http://js.foundation\n"+ | ||||
|             " *\n"+ | ||||
|             " * Licensed under the Apache License, Version 2.0 (the \"License\");\n"+ | ||||
|             " * you may not use this file except in compliance with the License.\n"+ | ||||
|             " * You may obtain a copy of the License at\n"+ | ||||
|             " *\n"+ | ||||
|             " * http://www.apache.org/licenses/LICENSE-2.0\n"+ | ||||
|             " *\n"+ | ||||
|             " * Unless required by applicable law or agreed to in writing, software\n"+ | ||||
|             " * distributed under the License is distributed on an \"AS IS\" BASIS,\n"+ | ||||
|             " * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n"+ | ||||
|             " * See the License for the specific language governing permissions and\n"+ | ||||
|             " * limitations under the License.\n"+ | ||||
|             " **/\n"; | ||||
|  | ||||
|         if (files) { | ||||
|             for (var i=0; i<files.length; i++) { | ||||
|                 var file = files[i]; | ||||
|                 if (!grunt.file.exists(file)) { | ||||
|                     grunt.log.warn('File '+ file + ' not found'); | ||||
|                     return false; | ||||
|                 } else { | ||||
|                     var content = grunt.file.read(file); | ||||
|                     if (content.indexOf(copyright) == -1) { | ||||
|                         content = copyright+content; | ||||
|                         if (!grunt.file.write(file, content)) { | ||||
|                             return false; | ||||
|                         } | ||||
|                         grunt.log.writeln("Attached copyright to "+file); | ||||
|                     } else { | ||||
|                         grunt.log.writeln("Copyright already on "+file); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     }); | ||||
|  | ||||
|     grunt.registerTask('setDevEnv', | ||||
|         'Sets NODE_ENV=development so non-minified assets are used', | ||||
|             function () { | ||||
|                 process.env.NODE_ENV = 'development'; | ||||
|             }); | ||||
|  | ||||
|     grunt.registerTask('default', | ||||
|         'Builds editor content then runs code style checks and unit tests on all components', | ||||
|         ['build','test-core','test-editor','test-nodes']); | ||||
|  | ||||
|     grunt.registerTask('test-core', | ||||
|         'Runs code style check and unit tests on core runtime code', | ||||
|         ['build','mocha_istanbul:core']); | ||||
|  | ||||
|     grunt.registerTask('test-editor', | ||||
|         'Runs code style check on editor code', | ||||
|         ['jshint:editor']); | ||||
|  | ||||
|     grunt.registerTask('test-ui', | ||||
|         'Builds editor content then runs unit tests on editor ui', | ||||
|         ['build','jshint:editor','webdriver:all']); | ||||
|  | ||||
|     grunt.registerTask('test-nodes', | ||||
|         'Runs unit tests on core nodes', | ||||
|         ['build','mocha_istanbul:nodes']); | ||||
|  | ||||
|     grunt.registerTask('build', | ||||
|         'Builds editor content', | ||||
|         ['clean:build','jsonlint','concat:build','concat:vendor','copy:build','uglify:build','sass:build','attachCopyright']); | ||||
|  | ||||
|     grunt.registerTask('dev', | ||||
|         'Developer mode: run node-red, watch for source changes and build/restart', | ||||
|         ['build','setDevEnv','concurrent:dev']); | ||||
|  | ||||
|     grunt.registerTask('release', | ||||
|         'Create distribution zip file', | ||||
|         ['build','clean:release','copy:release','chmod:release','compress:release']); | ||||
|  | ||||
|     grunt.registerTask('coverage', | ||||
|         'Run Istanbul code test coverage task', | ||||
|         ['build','mocha_istanbul:all']); | ||||
| }; | ||||
|   | ||||
							
								
								
									
										57
									
								
								INSTALL.md
									
									
									
									
									
								
							
							
						
						| @@ -1,57 +0,0 @@ | ||||
| Node-RED Install | ||||
| ================ | ||||
|  | ||||
| ## Install node.js | ||||
|  | ||||
| You can get the latest version from <http://nodejs.org/download/>. | ||||
|  | ||||
| Or, you may want to use a version from your operating system's package manager: | ||||
|  <https://github.com/joyent/node/wiki/Installing-Node.js-via-package-manager> | ||||
|  | ||||
| ## Get Node-RED | ||||
|  | ||||
| Clone the repository from GitHub: | ||||
|  | ||||
|     $ git clone git@github.com:node-red/node-red.git | ||||
|  | ||||
| ## Install the pre-requisite modules | ||||
|  | ||||
| From the top-level directory of Node-RED, run: | ||||
|  | ||||
|     $ npm install | ||||
|  | ||||
| This will install the core pre-requisite modules. | ||||
|  | ||||
| ## Run Node-RED | ||||
|  | ||||
| From the top-level directory, run: | ||||
|  | ||||
|     $ node red.js | ||||
|  | ||||
| You can then access Node-RED at <http://localhost:1880>. | ||||
|  | ||||
| Online documentation is available at <http://nodered.org/docs>. | ||||
|  | ||||
| ## Installing individual node dependencies | ||||
|  | ||||
| When Node-RED starts, it attempts to load the nodes from the `nodes/` directory. | ||||
| Each will have its own set of dependencies that will need to be installed before | ||||
| the node is available in the palette. | ||||
|  | ||||
| To help identify the dependencies, Node-RED logs any modules it fails to find | ||||
| for a particular node. You don't have to install these unless you want or need | ||||
| that node to appear. | ||||
|  | ||||
| Alternatively, a node's `.js` file can be examined to identify the modules it | ||||
| explicitly requires. For example, the Twitter node is defined in | ||||
| `nodes/social/27-twitter.js` and contains: | ||||
|  | ||||
| 	var RED = require("../../red/red"); | ||||
| 	var ntwitter = require('ntwitter'); | ||||
| 	var OAuth= require('oauth').OAuth; | ||||
|  | ||||
| Of these, `ntwitter` and `oauth` are neither built-in modules nor ones provided | ||||
| by Node-RED itself. They can subsequently be installed by running: | ||||
|  | ||||
|     $ npm install ntwitter oauth | ||||
|  | ||||
							
								
								
									
										1
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						| @@ -1,3 +1,4 @@ | ||||
| Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  | ||||
|                                  Apache License | ||||
|                            Version 2.0, January 2004 | ||||
|   | ||||
							
								
								
									
										60
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -2,49 +2,73 @@ | ||||
|  | ||||
| http://nodered.org | ||||
|  | ||||
| [](https://travis-ci.org/node-red/node-red) [](https://coveralls.io/r/node-red/node-red?branch=master) | ||||
|  | ||||
| [](https://travis-ci.org/node-red/node-red) | ||||
| [](https://coveralls.io/r/node-red/node-red?branch=master) | ||||
|  | ||||
| A visual tool for wiring the Internet of Things. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Quick Start | ||||
|  | ||||
| Check out [INSTALL](INSTALL.md) for full instructions on getting started. | ||||
| Check out http://nodered.org/docs/getting-started/ for full instructions on getting | ||||
| started. | ||||
|  | ||||
| 1. download the zip and unzip, or git clone | ||||
| 2. cd node-red | ||||
| 3. npm install | ||||
| 4. node red.js | ||||
| 5. Open <http://localhost:1880> | ||||
| 1. `sudo npm install -g --unsafe-perm node-red` | ||||
| 2. `node-red` | ||||
| 3. Open <http://localhost:1880> | ||||
|  | ||||
| ## Getting Help | ||||
|  | ||||
| More documentation can be found [here](http://nodered.org/docs). | ||||
|  | ||||
| For further help, or general discussion, please use the [mailing list](https://groups.google.com/forum/#!forum/node-red). | ||||
| For further help, or general discussion, please use the | ||||
| [mailing list](https://groups.google.com/forum/#!forum/node-red). | ||||
|  | ||||
| ## Browser Support | ||||
| ## Developers | ||||
|  | ||||
| The Node-RED editor runs in the browser. We routinely develop and test using | ||||
| Chrome and Firefox. We have anecdotal evidence that it works in recent versions of IE. | ||||
| If you want to run the latest code from git, here's how to get started: | ||||
|  | ||||
| We have basic support for using in mobile/tablet browsers. | ||||
| 1. Clone the code: | ||||
|  | ||||
|         git clone https://github.com/node-red/node-red.git | ||||
|         cd node-red | ||||
|  | ||||
| 2. Install the node-red dependencies | ||||
|  | ||||
|         npm install | ||||
|  | ||||
| 3. Build the code | ||||
|  | ||||
|         npm run build | ||||
|  | ||||
| 4. Run | ||||
|  | ||||
|         npm start | ||||
|    or | ||||
|  | ||||
|         node red.js | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| Before raising a pull-request, please read our [contributing guide](https://github.com/node-red/node-red/blob/master/CONTRIBUTING.md). | ||||
| Before raising a pull-request, please read our | ||||
| [contributing guide](https://github.com/node-red/node-red/blob/master/CONTRIBUTING.md). | ||||
|  | ||||
| This project adheres to the [Contributor Covenant 1.4](http://contributor-covenant.org/version/1/4/). | ||||
|  By participating, you are expected to uphold this code. Please report unacceptable | ||||
|  behavior to any of the project's core team at team@nodered.org. | ||||
|  | ||||
| ## Authors | ||||
|  | ||||
| Node-RED is a creation of [IBM Emerging Technology](http://ibm.com/blogs/et). | ||||
| Node-RED is a project of the [JS Foundation](http://js.foundation). | ||||
|  | ||||
| It was created by [IBM Emerging Technology](https://www.ibm.com/blogs/emerging-technology/). | ||||
|  | ||||
| * Nick O'Leary [@knolleary](http://twitter.com/knolleary) | ||||
| * Dave Conway-Jones [@ceejay](http://twitter.com/ceejay) | ||||
|  | ||||
| For more open-source projects from IBM, head over [here](http://ibm.github.io). | ||||
|  | ||||
|  | ||||
| ## Copyright and license | ||||
|  | ||||
| Copyright 2013, 2015 IBM Corp. under [the Apache 2.0 license](LICENSE). | ||||
| Copyright JS Foundation and other contributors, http://js.foundation under [the Apache 2.0 license](LICENSE). | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| #!/bin/bash | ||||
| # | ||||
| # Copyright 2015 IBM Corp. | ||||
| # Copyright JS Foundation and other contributors, http://js.foundation | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| @@ -31,7 +31,7 @@ done | ||||
| # Find the real location of this script | ||||
| CURRENT_PATH=`pwd` | ||||
| SCRIPT_PATH="${BASH_SOURCE[0]}"; | ||||
| while([ -h "${SCRIPT_PATH}" ]); do | ||||
| while [ -h "${SCRIPT_PATH}" ]; do | ||||
|     cd "`dirname "${SCRIPT_PATH}"`" | ||||
|     SCRIPT_PATH="$(readlink "`basename "${SCRIPT_PATH}"`")"; | ||||
| done | ||||
| @@ -40,4 +40,4 @@ SCRIPT_PATH="`pwd`"; | ||||
| cd $CURRENT_PATH | ||||
|  | ||||
| # Run Node-RED | ||||
| /usr/bin/env node $OPTIONS $SCRIPT_PATH/../red.js $ARGS | ||||
| exec /usr/bin/env node $OPTIONS $SCRIPT_PATH/../red.js $ARGS | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								editor/favicon.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 17 KiB | 
| Before Width: | Height: | Size: 308 B After Width: | Height: | Size: 308 B | 
| Before Width: | Height: | Size: 603 B After Width: | Height: | Size: 603 B | 
| Before Width: | Height: | Size: 393 B After Width: | Height: | Size: 393 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/batch.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 712 B | 
| Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 2.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/bridge-dash.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 508 B | 
| Before Width: | Height: | Size: 575 B After Width: | Height: | Size: 575 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/cog.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 493 B | 
| Before Width: | Height: | Size: 601 B After Width: | Height: | Size: 601 B | 
| Before Width: | Height: | Size: 459 B After Width: | Height: | Size: 459 B | 
| Before Width: | Height: | Size: 218 B After Width: | Height: | Size: 218 B | 
| Before Width: | Height: | Size: 324 B After Width: | Height: | Size: 324 B | 
| Before Width: | Height: | Size: 378 B After Width: | Height: | Size: 378 B | 
| Before Width: | Height: | Size: 255 B After Width: | Height: | Size: 255 B | 
| Before Width: | Height: | Size: 457 B After Width: | Height: | Size: 457 B | 
| Before Width: | Height: | Size: 502 B After Width: | Height: | Size: 502 B | 
| Before Width: | Height: | Size: 449 B After Width: | Height: | Size: 449 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/join.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 253 B | 
| Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 639 B After Width: | Height: | Size: 639 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/link-out.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 402 B | 
| Before Width: | Height: | Size: 414 B After Width: | Height: | Size: 414 B | 
| Before Width: | Height: | Size: 671 B After Width: | Height: | Size: 671 B | 
| Before Width: | Height: | Size: 386 B After Width: | Height: | Size: 386 B | 
| Before Width: | Height: | Size: 386 B After Width: | Height: | Size: 386 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/parser-csv.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 413 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/parser-html.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 393 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/parser-json.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 467 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/parser-xml.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 393 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/parser-yaml.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 423 B | 
| Before Width: | Height: | Size: 360 B After Width: | Height: | Size: 360 B | 
| Before Width: | Height: | Size: 736 B After Width: | Height: | Size: 736 B | 
| Before Width: | Height: | Size: 482 B After Width: | Height: | Size: 482 B | 
| Before Width: | Height: | Size: 273 B After Width: | Height: | Size: 273 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/sort.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 793 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/icons/split.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 256 B | 
| Before Width: | Height: | Size: 439 B After Width: | Height: | Size: 439 B | 
| Before Width: | Height: | Size: 592 B After Width: | Height: | Size: 592 B | 
| Before Width: | Height: | Size: 509 B After Width: | Height: | Size: 509 B | 
| Before Width: | Height: | Size: 488 B After Width: | Height: | Size: 488 B | 
| Before Width: | Height: | Size: 628 B After Width: | Height: | Size: 628 B | 
| Before Width: | Height: | Size: 258 B After Width: | Height: | Size: 258 B | 
| Before Width: | Height: | Size: 404 B After Width: | Height: | Size: 404 B | 
| Before Width: | Height: | Size: 591 B After Width: | Height: | Size: 591 B | 
| Before Width: | Height: | Size: 707 B After Width: | Height: | Size: 707 B | 
| Before Width: | Height: | Size: 291 B After Width: | Height: | Size: 291 B | 
| Before Width: | Height: | Size: 386 B After Width: | Height: | Size: 386 B | 
| Before Width: | Height: | Size: 289 B After Width: | Height: | Size: 289 B | 
| Before Width: | Height: | Size: 368 B After Width: | Height: | Size: 368 B | 
| Before Width: | Height: | Size: 290 B After Width: | Height: | Size: 290 B | 
| Before Width: | Height: | Size: 392 B After Width: | Height: | Size: 392 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/grip.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 192 B | 
| Before Width: | Height: | Size: 8.3 KiB After Width: | Height: | Size: 8.3 KiB | 
							
								
								
									
										9
									
								
								editor/images/node-red-icon-black.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,9 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> | ||||
| <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0" y="0" width="480" height="480" viewBox="0, 0, 480, 480"> | ||||
|   <g id="Calque_1"> | ||||
|     <path d="M408,16 C438.928,16 464,41.072 464,72 L464,408 C464,438.928 438.928,464 408,464 L72,464 C41.072,464 16,438.928 16,408 L16,296.002 L69.339,296.002 C89.715,296.002 105.993,279.497 105.993,259.12 L105.992,242.19 C190.296,243.397 214.83,265.317 241.661,288.777 C267.502,311.375 296.48,335.662 371.989,336.261 L371.993,344.57 C372.002,364.947 388.693,382 409.069,382 L463.991,382 L463.991,356 L409.069,356 C402.189,356 396.991,351.449 396.991,344.569 L396.991,308.32 C396.991,301.44 402.189,296 409.069,296 L463.991,296 L463.991,272 L409.069,272 C388.693,272 372.002,287.943 371.993,308.32 L371.99,316.908 C300.63,316.672 280.362,296.883 254.41,274.189 C232.267,254.825 206.244,233.534 148.914,225.789 C149.412,225.361 149.872,224.945 150.353,224.505 C161.391,214.382 167.343,202.153 173.167,191.593 C178.99,181.034 184.469,172.221 193.444,166.061 C200.725,161.064 211.08,157.338 226.992,156.647 L226.993,165.123 C226.997,185.5 243.431,202.999 263.808,202.999 L411.141,202.999 C431.517,202.999 447.993,185.5 447.993,165.123 L447.993,128.874 C447.993,108.497 431.517,91.999 411.141,91.999 L263.808,91.999 C243.431,91.999 226.983,108.496 226.993,128.874 L226.998,137.281 C207.794,138.053 193.238,142.713 182.496,150.086 C169.469,159.028 162.277,171.247 156.21,182.247 C150.144,193.247 145.009,203.104 137.25,210.218 C130.497,216.411 121.157,221.193 105.993,222.976 L105.993,222.579 C106.111,202.203 89.715,186.002 69.339,186.002 L16,186.002 L16,72 C16,41.072 41.072,16 72,16 L408,16 z" fill="#000000"/> | ||||
|     <path d="M16,211.002 L69.339,211.002 C76.219,211.002 81.992,215.991 81.992,222.871 L81.992,259.12 C81.992,266 76.219,272.002 69.339,272.002 L16,272.002 L16,211.002 z" fill="#000000"/> | ||||
|     <path d="M411.135,116.997 C418.015,116.997 422.987,121.992 422.987,128.872 L422.987,165.122 C422.987,172.002 418.015,176.998 411.135,176.998 L263.802,176.998 C256.923,176.998 250.99,172.002 250.99,165.122 L250.99,128.872 C250.99,121.993 256.923,116.997 263.802,116.997 L411.135,116.997 z" fill="#000000"/> | ||||
|   </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 2.3 KiB | 
							
								
								
									
										33
									
								
								editor/images/node-red-icon.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,33 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||
| <svg xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://www.w3.org/2000/svg" height="480" width="480" version="1.1" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" viewBox="0 0 480.00002 479.99999"> | ||||
|  <title>Node-RED Icon</title> | ||||
|  <metadata> | ||||
|   <rdf:RDF> | ||||
|    <cc:Work rdf:about=""> | ||||
|     <dc:format>image/svg+xml</dc:format> | ||||
|     <dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage"/> | ||||
|     <dc:title>Node-RED Icon</dc:title> | ||||
|     <cc:license rdf:resource="http://creativecommons.org/licenses/by/3.0/"/> | ||||
|     <dc:creator> | ||||
|      <cc:Agent> | ||||
|       <dc:title>Nick O'Leary</dc:title> | ||||
|      </cc:Agent> | ||||
|     </dc:creator> | ||||
|    </cc:Work> | ||||
|    <cc:License rdf:about="http://creativecommons.org/licenses/by/3.0/"> | ||||
|     <cc:permits rdf:resource="http://creativecommons.org/ns#Reproduction"/> | ||||
|     <cc:permits rdf:resource="http://creativecommons.org/ns#Distribution"/> | ||||
|     <cc:requires rdf:resource="http://creativecommons.org/ns#Notice"/> | ||||
|     <cc:requires rdf:resource="http://creativecommons.org/ns#Attribution"/> | ||||
|     <cc:permits rdf:resource="http://creativecommons.org/ns#DerivativeWorks"/> | ||||
|    </cc:License> | ||||
|   </rdf:RDF> | ||||
|  </metadata> | ||||
|  <g transform="translate(0 -572.36)"> | ||||
|   <rect style="color-rendering:auto;color:#000000;isolation:auto;mix-blend-mode:normal;shape-rendering:auto;solid-color:#000000;image-rendering:auto" ry="56" height="448" width="448" y="588.36" x="16" fill="#8f0000"/> | ||||
|   <g transform="matrix(8.545 0 0 8.545 -786.19 -1949.8)"> | ||||
|    <path style="color-rendering:auto;text-decoration-color:#000000;color:#000000;isolation:auto;mix-blend-mode:normal;shape-rendering:auto;solid-color:#000000;block-progression:tb;text-decoration-line:none;text-decoration-style:solid;image-rendering:auto;white-space:normal;text-indent:0;text-transform:none" d="m104.41 321.21c0.0138-2.3846-1.905-4.2806-4.2896-4.2806h-6.243v2.9257h6.243c0.80513 0 1.4808 0.58383 1.4808 1.389v4.2422c0 0.80513-0.67566 1.5075-1.4808 1.5075h-6.243v2.8086h6.243c2.3846 0 4.2895-1.9315 4.2895-4.3162l-0.00005-1.9812c9.8659 0.14125 12.737 2.7065 15.877 5.4519 3.0241 2.6446 6.4153 5.4869 15.252 5.557l0.00046 0.97238c0.001 2.3846 1.9543 4.3803 4.3389 4.3803h6.4273v-3.0427h-6.4273c-0.80514 0-1.4135-0.53255-1.4135-1.3377v-4.2422c0-0.80513 0.60835-1.4418 1.4135-1.4418h6.4273v-2.8086h-6.4273c-2.3846 0-4.3379 1.8658-4.3389 4.2504l-0.00045 1.005c-8.351-0.0276-10.723-2.3434-13.76-4.9992-2.5914-2.2662-5.6368-4.7578-12.346-5.6642 0.0583-0.0501 0.11211-0.0987 0.16838-0.15027 1.2918-1.1846 1.9884-2.6158 2.6699-3.8516 0.68148-1.2357 1.3227-2.267 2.373-2.9879 0.85207-0.58483 2.0639-1.0208 3.926-1.1017l0.00018 0.99192c0.00043 2.3846 1.9236 4.4325 4.3083 4.4325h17.242c2.3846 0 4.3127-2.0479 4.3127-4.4325v-4.2422c0-2.3846-1.9281-4.3153-4.3127-4.3153h-17.242c-2.3846 0-4.3095 1.9306-4.3083 4.3153l0.00051 0.98395c-2.2474 0.0903-3.9508 0.6357-5.2079 1.4985-1.5245 1.0464-2.3662 2.4764-3.0762 3.7637-0.70992 1.2873-1.3108 2.4408-2.2188 3.2734-0.79034 0.72475-1.8834 1.2844-3.658 1.493zm18.468-12.356h17.242c0.80514 0 1.387 0.58455 1.387 1.3897v4.2422c0 0.80514-0.5819 1.3898-1.387 1.3898h-17.242c-0.80514 0-1.4994-0.58462-1.4994-1.3898v-4.2422c0-0.80513 0.69431-1.3897 1.4994-1.3897z" fill="#fff"/> | ||||
|   </g> | ||||
|  </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 3.3 KiB | 
| Before Width: | Height: | Size: 1019 B After Width: | Height: | Size: 1019 B | 
| Before Width: | Height: | Size: 600 B After Width: | Height: | Size: 600 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/subflow_tab.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 410 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/09.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 638 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/az.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 546 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/bin.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 638 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/bool.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 646 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/expr.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 563 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/json.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 588 B | 
							
								
								
									
										
											BIN
										
									
								
								editor/images/typedInput/re.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 502 B | 
							
								
								
									
										168
									
								
								editor/js/comms.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,168 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
| RED.comms = (function() { | ||||
|  | ||||
|     var errornotification = null; | ||||
|     var clearErrorTimer = null; | ||||
|     var connectCountdownTimer = null; | ||||
|     var connectCountdown = 10; | ||||
|     var subscriptions = {}; | ||||
|     var ws; | ||||
|     var pendingAuth = false; | ||||
|     var reconnectAttempts = 0; | ||||
|     var active = false; | ||||
|  | ||||
|     function connectWS() { | ||||
|         active = true; | ||||
|         var path = location.hostname; | ||||
|         var port = location.port; | ||||
|         if (port.length !== 0) { | ||||
|             path = path+":"+port; | ||||
|         } | ||||
|         path = path+document.location.pathname; | ||||
|         path = path+(path.slice(-1) == "/"?"":"/")+"comms"; | ||||
|         path = "ws"+(document.location.protocol=="https:"?"s":"")+"://"+path; | ||||
|  | ||||
|         var auth_tokens = RED.settings.get("auth-tokens"); | ||||
|         pendingAuth = (auth_tokens!=null); | ||||
|  | ||||
|         function completeConnection() { | ||||
|             for (var t in subscriptions) { | ||||
|                 if (subscriptions.hasOwnProperty(t)) { | ||||
|                     ws.send(JSON.stringify({subscribe:t})); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         ws = new WebSocket(path); | ||||
|         ws.onopen = function() { | ||||
|             reconnectAttempts = 0; | ||||
|             if (errornotification) { | ||||
|                 clearErrorTimer = setTimeout(function() { | ||||
|                     errornotification.close(); | ||||
|                     errornotification = null; | ||||
|                 },1000); | ||||
|             } | ||||
|             if (pendingAuth) { | ||||
|                 ws.send(JSON.stringify({auth:auth_tokens.access_token})); | ||||
|             } else { | ||||
|                 completeConnection(); | ||||
|             } | ||||
|         } | ||||
|         ws.onmessage = function(event) { | ||||
|             var message = JSON.parse(event.data); | ||||
|             for (var m = 0; m < message.length; m++) { | ||||
|                 var msg = message[m]; | ||||
|                 if (pendingAuth && msg.auth) { | ||||
|                     if (msg.auth === "ok") { | ||||
|                         pendingAuth = false; | ||||
|                         completeConnection(); | ||||
|                     } else if (msg.auth === "fail") { | ||||
|                         // anything else is an error... | ||||
|                         active = false; | ||||
|                         RED.user.login({updateMenu:true},function() { | ||||
|                             connectWS(); | ||||
|                         }) | ||||
|                     } | ||||
|                 } | ||||
|                 else if (msg.topic) { | ||||
|                     for (var t in subscriptions) { | ||||
|                         if (subscriptions.hasOwnProperty(t)) { | ||||
|                             var re = new RegExp("^"+t.replace(/([\[\]\?\(\)\\\\$\^\*\.|])/g,"\\$1").replace(/\+/g,"[^/]+").replace(/\/#$/,"(\/.*)?")+"$"); | ||||
|                             if (re.test(msg.topic)) { | ||||
|                                 var subscribers = subscriptions[t]; | ||||
|                                 if (subscribers) { | ||||
|                                     for (var i=0;i<subscribers.length;i++) { | ||||
|                                         subscribers[i](msg.topic,msg.data); | ||||
|                                     } | ||||
|                                 } | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         }; | ||||
|         ws.onclose = function() { | ||||
|             if (!active) { | ||||
|                 return; | ||||
|             } | ||||
|             if (clearErrorTimer) { | ||||
|                 clearTimeout(clearErrorTimer); | ||||
|                 clearErrorTimer = null; | ||||
|             } | ||||
|             reconnectAttempts++; | ||||
|             if (reconnectAttempts < 10) { | ||||
|                 setTimeout(connectWS,1000); | ||||
|                 if (reconnectAttempts > 5 && errornotification == null) { | ||||
|                     errornotification = RED.notify(RED._("notification.errors.lostConnection"),"error",true); | ||||
|                 } | ||||
|             } else if (reconnectAttempts < 20) { | ||||
|                 setTimeout(connectWS,2000); | ||||
|             } else { | ||||
|                 connectCountdown = 60; | ||||
|                 connectCountdownTimer = setInterval(function() { | ||||
|                     connectCountdown--; | ||||
|                     if (connectCountdown === 0) { | ||||
|                         errornotification.update(RED._("notification.errors.lostConnection")); | ||||
|                         clearInterval(connectCountdownTimer); | ||||
|                         connectWS(); | ||||
|                     } else { | ||||
|                         var msg = RED._("notification.errors.lostConnectionReconnect",{time: connectCountdown})+' <a href="#">'+ RED._("notification.errors.lostConnectionTry")+'</a>'; | ||||
|                         errornotification.update(msg); | ||||
|                         $(errornotification).find("a").click(function(e) { | ||||
|                             e.preventDefault(); | ||||
|                             errornotification.update(RED._("notification.errors.lostConnection")); | ||||
|                             clearInterval(connectCountdownTimer); | ||||
|                             connectWS(); | ||||
|                         }) | ||||
|                     } | ||||
|                 },1000); | ||||
|             } | ||||
|  | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function subscribe(topic,callback) { | ||||
|         if (subscriptions[topic] == null) { | ||||
|             subscriptions[topic] = []; | ||||
|         } | ||||
|         subscriptions[topic].push(callback); | ||||
|         if (ws && ws.readyState == 1) { | ||||
|             ws.send(JSON.stringify({subscribe:topic})); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function unsubscribe(topic,callback) { | ||||
|         if (subscriptions[topic]) { | ||||
|             for (var i=0;i<subscriptions[topic].length;i++) { | ||||
|                 if (subscriptions[topic][i] === callback) { | ||||
|                     subscriptions[topic].splice(i,1); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|             if (subscriptions[topic].length === 0) { | ||||
|                 delete subscriptions[topic]; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return { | ||||
|         connect: connectWS, | ||||
|         subscribe: subscribe, | ||||
|         unsubscribe:unsubscribe | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										53
									
								
								editor/js/events.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,53 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
|  RED.events = (function() { | ||||
|      var handlers = {}; | ||||
|  | ||||
|      function on(evt,func) { | ||||
|          handlers[evt] = handlers[evt]||[]; | ||||
|          handlers[evt].push(func); | ||||
|      } | ||||
|      function off(evt,func) { | ||||
|          var handler = handlers[evt]; | ||||
|          if (handler) { | ||||
|              for (var i=0;i<handler.length;i++) { | ||||
|                  if (handler[i] === func) { | ||||
|                      handler.splice(i,1); | ||||
|                      return; | ||||
|                  } | ||||
|              } | ||||
|          } | ||||
|      } | ||||
|      function emit(evt,arg) { | ||||
|          if (handlers[evt]) { | ||||
|              for (var i=0;i<handlers[evt].length;i++) { | ||||
|                  try { | ||||
|                      handlers[evt][i](arg); | ||||
|                  } catch(err) { | ||||
|                      console.log("RED.events.emit error: ["+evt+"] "+(err.toString())); | ||||
|                      console.log(err); | ||||
|                  } | ||||
|              } | ||||
|  | ||||
|          } | ||||
|      } | ||||
|      return { | ||||
|          on: on, | ||||
|          off: off, | ||||
|          emit: emit | ||||
|      } | ||||
|  })(); | ||||
							
								
								
									
										332
									
								
								editor/js/history.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,332 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| RED.history = (function() { | ||||
|     var undo_history = []; | ||||
|  | ||||
|     function undoEvent(ev) { | ||||
|         var i; | ||||
|         var len; | ||||
|         var node; | ||||
|         var subflow; | ||||
|         var modifiedTabs = {}; | ||||
|         if (ev) { | ||||
|             if (ev.t == 'multi') { | ||||
|                 len = ev.events.length; | ||||
|                 for (i=len-1;i>=0;i--) { | ||||
|                     undoEvent(ev.events[i]); | ||||
|                 } | ||||
|             } else if (ev.t == 'replace') { | ||||
|                 RED.nodes.clear(); | ||||
|                 var imported = RED.nodes.import(ev.config); | ||||
|                 imported[0].forEach(function(n) { | ||||
|                     if (ev.changed[n.id]) { | ||||
|                         n.changed = true; | ||||
|                     } | ||||
|                 }) | ||||
|  | ||||
|                 RED.nodes.version(ev.rev); | ||||
|             } else if (ev.t == 'add') { | ||||
|                 if (ev.nodes) { | ||||
|                     for (i=0;i<ev.nodes.length;i++) { | ||||
|                         node = RED.nodes.node(ev.nodes[i]); | ||||
|                         if (node.z) { | ||||
|                             modifiedTabs[node.z] = true; | ||||
|                         } | ||||
|                         RED.nodes.remove(ev.nodes[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.links) { | ||||
|                     for (i=0;i<ev.links.length;i++) { | ||||
|                         RED.nodes.removeLink(ev.links[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.workspaces) { | ||||
|                     for (i=0;i<ev.workspaces.length;i++) { | ||||
|                         RED.nodes.removeWorkspace(ev.workspaces[i].id); | ||||
|                         RED.workspaces.remove(ev.workspaces[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.subflows) { | ||||
|                     for (i=0;i<ev.subflows.length;i++) { | ||||
|                         RED.nodes.removeSubflow(ev.subflows[i]); | ||||
|                         RED.workspaces.remove(ev.subflows[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.subflow) { | ||||
|                     if (ev.subflow.instances) { | ||||
|                         ev.subflow.instances.forEach(function(n) { | ||||
|                             var node = RED.nodes.node(n.id); | ||||
|                             if (node) { | ||||
|                                 node.changed = n.changed; | ||||
|                                 node.dirty = true; | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                     if (ev.subflow.hasOwnProperty('changed')) { | ||||
|                         subflow = RED.nodes.subflow(ev.subflow.id); | ||||
|                         if (subflow) { | ||||
|                             subflow.changed = ev.subflow.changed; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.removedLinks) { | ||||
|                     for (i=0;i<ev.removedLinks.length;i++) { | ||||
|                         RED.nodes.addLink(ev.removedLinks[i]); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|             } else if (ev.t == "delete") { | ||||
|                 if (ev.workspaces) { | ||||
|                     for (i=0;i<ev.workspaces.length;i++) { | ||||
|                         RED.nodes.addWorkspace(ev.workspaces[i]); | ||||
|                         RED.workspaces.add(ev.workspaces[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.subflow && ev.subflow.subflow) { | ||||
|                     RED.nodes.addSubflow(ev.subflow.subflow); | ||||
|                 } | ||||
|                 if (ev.subflowInputs && ev.subflowInputs.length > 0) { | ||||
|                     subflow = RED.nodes.subflow(ev.subflowInputs[0].z); | ||||
|                     subflow.in.push(ev.subflowInputs[0]); | ||||
|                     subflow.in[0].dirty = true; | ||||
|                 } | ||||
|                 if (ev.subflowOutputs && ev.subflowOutputs.length > 0) { | ||||
|                     subflow = RED.nodes.subflow(ev.subflowOutputs[0].z); | ||||
|                     ev.subflowOutputs.sort(function(a,b) { return a.i-b.i}); | ||||
|                     for (i=0;i<ev.subflowOutputs.length;i++) { | ||||
|                         var output = ev.subflowOutputs[i]; | ||||
|                         subflow.out.splice(output.i,0,output); | ||||
|                         for (var j=output.i+1;j<subflow.out.length;j++) { | ||||
|                             subflow.out[j].i++; | ||||
|                             subflow.out[j].dirty = true; | ||||
|                         } | ||||
|                         RED.nodes.eachLink(function(l) { | ||||
|                             if (l.source.type == "subflow:"+subflow.id) { | ||||
|                                 if (l.sourcePort >= output.i) { | ||||
|                                     l.sourcePort++; | ||||
|                                 } | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.subflow && ev.subflow.hasOwnProperty('instances')) { | ||||
|                     ev.subflow.instances.forEach(function(n) { | ||||
|                         var node = RED.nodes.node(n.id); | ||||
|                         if (node) { | ||||
|                             node.changed = n.changed; | ||||
|                             node.dirty = true; | ||||
|                         } | ||||
|                     }); | ||||
|                 } | ||||
|                 if (subflow) { | ||||
|                     RED.nodes.filterNodes({type:"subflow:"+subflow.id}).forEach(function(n) { | ||||
|                         n.inputs = subflow.in.length; | ||||
|                         n.outputs = subflow.out.length; | ||||
|                         while (n.outputs > n.ports.length) { | ||||
|                             n.ports.push(n.ports.length); | ||||
|                         } | ||||
|                         n.resize = true; | ||||
|                         n.dirty = true; | ||||
|                     }); | ||||
|                 } | ||||
|                 if (ev.nodes) { | ||||
|                     for (i=0;i<ev.nodes.length;i++) { | ||||
|                         RED.nodes.add(ev.nodes[i]); | ||||
|                         modifiedTabs[ev.nodes[i].z] = true; | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.links) { | ||||
|                     for (i=0;i<ev.links.length;i++) { | ||||
|                         RED.nodes.addLink(ev.links[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.changes) { | ||||
|                     for (i in ev.changes) { | ||||
|                         if (ev.changes.hasOwnProperty(i)) { | ||||
|                             node = RED.nodes.node(i); | ||||
|                             if (node) { | ||||
|                                 for (var d in ev.changes[i]) { | ||||
|                                     if (ev.changes[i].hasOwnProperty(d)) { | ||||
|                                         node[d] = ev.changes[i][d]; | ||||
|                                     } | ||||
|                                 } | ||||
|                                 node.dirty = true; | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|  | ||||
|                 } | ||||
|             } else if (ev.t == "move") { | ||||
|                 for (i=0;i<ev.nodes.length;i++) { | ||||
|                     var n = ev.nodes[i]; | ||||
|                     n.n.x = n.ox; | ||||
|                     n.n.y = n.oy; | ||||
|                     n.n.dirty = true; | ||||
|                     n.n.moved = n.moved; | ||||
|                 } | ||||
|                 // A move could have caused a link splice | ||||
|                 if (ev.links) { | ||||
|                     for (i=0;i<ev.links.length;i++) { | ||||
|                         RED.nodes.removeLink(ev.links[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.removedLinks) { | ||||
|                     for (i=0;i<ev.removedLinks.length;i++) { | ||||
|                         RED.nodes.addLink(ev.removedLinks[i]); | ||||
|                     } | ||||
|                 } | ||||
|             } else if (ev.t == "edit") { | ||||
|                 for (i in ev.changes) { | ||||
|                     if (ev.changes.hasOwnProperty(i)) { | ||||
|                         if (ev.node._def.defaults && ev.node._def.defaults[i] && ev.node._def.defaults[i].type) { | ||||
|                             // This is a config node property | ||||
|                             var currentConfigNode = RED.nodes.node(ev.node[i]); | ||||
|                             if (currentConfigNode) { | ||||
|                                 currentConfigNode.users.splice(currentConfigNode.users.indexOf(ev.node),1); | ||||
|                             } | ||||
|                             var newConfigNode = RED.nodes.node(ev.changes[i]); | ||||
|                             if (newConfigNode) { | ||||
|                                 newConfigNode.users.push(ev.node); | ||||
|                             } | ||||
|                         } | ||||
|                         ev.node[i] = ev.changes[i]; | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.subflow) { | ||||
|                     if (ev.subflow.hasOwnProperty('inputCount')) { | ||||
|                         if (ev.node.in.length > ev.subflow.inputCount) { | ||||
|                             ev.node.in.splice(ev.subflow.inputCount); | ||||
|                         } else if (ev.subflow.inputs.length > 0) { | ||||
|                             ev.node.in = ev.node.in.concat(ev.subflow.inputs); | ||||
|                         } | ||||
|                     } | ||||
|                     if (ev.subflow.hasOwnProperty('outputCount')) { | ||||
|                         if (ev.node.out.length > ev.subflow.outputCount) { | ||||
|                             ev.node.out.splice(ev.subflow.outputCount); | ||||
|                         } else if (ev.subflow.outputs.length > 0) { | ||||
|                             ev.node.out = ev.node.out.concat(ev.subflow.outputs); | ||||
|                         } | ||||
|                     } | ||||
|                     if (ev.subflow.hasOwnProperty('instances')) { | ||||
|                         ev.subflow.instances.forEach(function(n) { | ||||
|                             var node = RED.nodes.node(n.id); | ||||
|                             if (node) { | ||||
|                                 node.changed = n.changed; | ||||
|                                 node.dirty = true; | ||||
|                             } | ||||
|                         }); | ||||
|                     } | ||||
|                     RED.editor.validateNode(ev.node); | ||||
|                     RED.nodes.filterNodes({type:"subflow:"+ev.node.id}).forEach(function(n) { | ||||
|                         n.inputs = ev.node.in.length; | ||||
|                         n.outputs = ev.node.out.length; | ||||
|                         RED.editor.updateNodeProperties(n); | ||||
|                         RED.editor.validateNode(n); | ||||
|                     }); | ||||
|                 } else { | ||||
|                     var outputMap; | ||||
|                     if (ev.outputMap) { | ||||
|                         outputMap = {}; | ||||
|                         for (var port in ev.outputMap) { | ||||
|                             if (ev.outputMap.hasOwnProperty(port) && ev.outputMap[port] !== "-1") { | ||||
|                                 outputMap[ev.outputMap[port]] = port; | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     RED.editor.updateNodeProperties(ev.node,outputMap); | ||||
|                     RED.editor.validateNode(ev.node); | ||||
|                 } | ||||
|                 if (ev.links) { | ||||
|                     for (i=0;i<ev.links.length;i++) { | ||||
|                         RED.nodes.addLink(ev.links[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 ev.node.dirty = true; | ||||
|                 ev.node.changed = ev.changed; | ||||
|             } else if (ev.t == "createSubflow") { | ||||
|                 if (ev.nodes) { | ||||
|                     RED.nodes.filterNodes({z:ev.subflow.subflow.id}).forEach(function(n) { | ||||
|                         n.z = ev.activeWorkspace; | ||||
|                         n.dirty = true; | ||||
|                     }); | ||||
|                     for (i=0;i<ev.nodes.length;i++) { | ||||
|                         RED.nodes.remove(ev.nodes[i]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (ev.links) { | ||||
|                     for (i=0;i<ev.links.length;i++) { | ||||
|                         RED.nodes.removeLink(ev.links[i]); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 RED.nodes.removeSubflow(ev.subflow.subflow); | ||||
|                 RED.workspaces.remove(ev.subflow.subflow); | ||||
|  | ||||
|                 if (ev.removedLinks) { | ||||
|                     for (i=0;i<ev.removedLinks.length;i++) { | ||||
|                         RED.nodes.addLink(ev.removedLinks[i]); | ||||
|                     } | ||||
|                 } | ||||
|             } else if (ev.t == "reorder") { | ||||
|                 if (ev.order) { | ||||
|                     RED.workspaces.order(ev.order); | ||||
|                 } | ||||
|             } | ||||
|             Object.keys(modifiedTabs).forEach(function(id) { | ||||
|                 var subflow = RED.nodes.subflow(id); | ||||
|                 if (subflow) { | ||||
|                     RED.editor.validateNode(subflow); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             RED.nodes.dirty(ev.dirty); | ||||
|             RED.view.redraw(true); | ||||
|             RED.palette.refresh(); | ||||
|             RED.workspaces.refresh(); | ||||
|             RED.sidebar.config.refresh(); | ||||
|         } | ||||
|  | ||||
|     } | ||||
|  | ||||
|     return { | ||||
|         //TODO: this function is a placeholder until there is a 'save' event that can be listened to | ||||
|         markAllDirty: function() { | ||||
|             for (var i=0;i<undo_history.length;i++) { | ||||
|                 undo_history[i].dirty = true; | ||||
|             } | ||||
|         }, | ||||
|         list: function() { | ||||
|             return undo_history | ||||
|         }, | ||||
|         depth: function() { | ||||
|             return undo_history.length; | ||||
|         }, | ||||
|         push: function(ev) { | ||||
|             undo_history.push(ev); | ||||
|         }, | ||||
|         pop: function() { | ||||
|             var ev = undo_history.pop(); | ||||
|             undoEvent(ev); | ||||
|         }, | ||||
|         peek: function() { | ||||
|             return undo_history[undo_history.length-1]; | ||||
|         }, | ||||
|         clear: function() { | ||||
|             undo_history = []; | ||||
|         } | ||||
|     } | ||||
|  | ||||
| })(); | ||||
							
								
								
									
										86
									
								
								editor/js/i18n.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,86 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
| RED.i18n = (function() { | ||||
|  | ||||
|     return { | ||||
|         init: function(done) { | ||||
|             i18n.init({ | ||||
|                 resGetPath: 'locales/__ns__?lng=__lng__', | ||||
|                 dynamicLoad: false, | ||||
|                 load:'current', | ||||
|                 ns: { | ||||
|                     namespaces: ["editor","node-red","jsonata","infotips"], | ||||
|                     defaultNs: "editor" | ||||
|                 }, | ||||
|                 fallbackLng: ['en-US'], | ||||
|                 useCookie: false | ||||
|             },function() { | ||||
|                 done(); | ||||
|             }); | ||||
|             RED["_"] = function() { | ||||
|                 return i18n.t.apply(null,arguments); | ||||
|             } | ||||
|  | ||||
|         }, | ||||
|         loadCatalog: function(namespace,done) { | ||||
|             var languageList = i18n.functions.toLanguages(i18n.detectLanguage()); | ||||
|             var toLoad = languageList.length; | ||||
|             languageList.forEach(function(lang) { | ||||
|                 $.ajax({ | ||||
|                     headers: { | ||||
|                         "Accept":"application/json" | ||||
|                     }, | ||||
|                     cache: false, | ||||
|                     url: 'locales/'+namespace+'?lng='+lang, | ||||
|                     success: function(data) { | ||||
|                         i18n.addResourceBundle(lang,namespace,data); | ||||
|                         toLoad--; | ||||
|                         if (toLoad === 0) { | ||||
|                             done(); | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|             }) | ||||
|  | ||||
|         }, | ||||
|  | ||||
|         loadNodeCatalogs: function(done) { | ||||
|             var languageList = i18n.functions.toLanguages(i18n.detectLanguage()); | ||||
|             var toLoad = languageList.length; | ||||
|  | ||||
|             languageList.forEach(function(lang) { | ||||
|                 $.ajax({ | ||||
|                     headers: { | ||||
|                         "Accept":"application/json" | ||||
|                     }, | ||||
|                     cache: false, | ||||
|                     url: 'locales/nodes?lng='+lang, | ||||
|                     success: function(data) { | ||||
|                         var namespaces = Object.keys(data); | ||||
|                         namespaces.forEach(function(ns) { | ||||
|                             i18n.addResourceBundle(lang,ns,data[ns]); | ||||
|                         }); | ||||
|                         toLoad--; | ||||
|                         if (toLoad === 0) { | ||||
|                             done(); | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|             }) | ||||
|         } | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										43
									
								
								editor/js/keymap.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,43 @@ | ||||
| { | ||||
|     "*": { | ||||
|         "ctrl-shift-p":"core:manage-palette", | ||||
|         "ctrl-f": "core:search", | ||||
|         "ctrl-=": "core:zoom-in", | ||||
|         "ctrl--": "core:zoom-out", | ||||
|         "ctrl-0": "core:zoom-reset", | ||||
|         "ctrl-enter": "core:confirm-edit-tray", | ||||
|         "ctrl-escape": "core:cancel-edit-tray", | ||||
|         "ctrl-g i": "core:show-info-tab", | ||||
|         "ctrl-g d": "core:show-debug-tab", | ||||
|         "ctrl-g c": "core:show-config-tab", | ||||
|         "ctrl-e": "core:show-export-dialog", | ||||
|         "ctrl-i": "core:show-import-dialog", | ||||
|         "ctrl-space": "core:toggle-sidebar", | ||||
|         "ctrl-,": "core:show-user-settings", | ||||
|         "ctrl-alt-r": "core:show-remote-diff", | ||||
|         "ctrl-alt-n": "core:new-project", | ||||
|         "ctrl-alt-o": "core:open-project", | ||||
|         "ctrl-g v": "core:show-version-control-tab" | ||||
|     }, | ||||
|     "workspace": { | ||||
|         "backspace": "core:delete-selection", | ||||
|         "delete": "core:delete-selection", | ||||
|         "enter": "core:edit-selected-node", | ||||
|         "ctrl-c": "core:copy-selection-to-internal-clipboard", | ||||
|         "ctrl-x": "core:cut-selection-to-internal-clipboard", | ||||
|         "ctrl-v": "core:paste-from-internal-clipboard", | ||||
|         "ctrl-z": "core:undo", | ||||
|         "ctrl-a": "core:select-all-nodes", | ||||
|         "shift-?": "core:show-help", | ||||
|         "up": "core:move-selection-up", | ||||
|         "right": "core:move-selection-right", | ||||
|         "down": "core:move-selection-down", | ||||
|         "left": "core:move-selection-left", | ||||
|         "shift-up": "core:step-selection-up", | ||||
|         "shift-right": "core:step-selection-right", | ||||
|         "shift-down": "core:step-selection-down", | ||||
|         "shift-left": "core:step-selection-left", | ||||
|         "ctrl-shift-j": "core:show-previous-tab", | ||||
|         "ctrl-shift-k": "core:show-next-tab" | ||||
|      } | ||||
| } | ||||
							
								
								
									
										478
									
								
								editor/js/main.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,478 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| (function() { | ||||
|  | ||||
|     function loadNodeList() { | ||||
|         $.ajax({ | ||||
|             headers: { | ||||
|                 "Accept":"application/json" | ||||
|             }, | ||||
|             cache: false, | ||||
|             url: 'nodes', | ||||
|             success: function(data) { | ||||
|                 RED.nodes.setNodeList(data); | ||||
|                 RED.i18n.loadNodeCatalogs(function() { | ||||
|                     loadIconList(loadNodes); | ||||
|                 }); | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function loadIconList(done) { | ||||
|         $.ajax({ | ||||
|             headers: { | ||||
|                 "Accept":"application/json" | ||||
|             }, | ||||
|             cache: false, | ||||
|             url: 'icons', | ||||
|             success: function(data) { | ||||
|                 RED.nodes.setIconSets(data); | ||||
|                 if (done) { | ||||
|                     done(); | ||||
|                 } | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function loadNodes() { | ||||
|         $.ajax({ | ||||
|             headers: { | ||||
|                 "Accept":"text/html" | ||||
|             }, | ||||
|             cache: false, | ||||
|             url: 'nodes', | ||||
|             success: function(data) { | ||||
|                 $("body").append(data); | ||||
|                 $("body").i18n(); | ||||
|                 $("#palette > .palette-spinner").hide(); | ||||
|                 $(".palette-scroll").removeClass("hide"); | ||||
|                 $("#palette-search").removeClass("hide"); | ||||
|                 loadFlows(function() { | ||||
|                     if (RED.settings.theme("projects.enabled",false)) { | ||||
|                         RED.projects.refresh(function(activeProject) { | ||||
|                             RED.sidebar.info.refresh() | ||||
|                             if (!activeProject) { | ||||
|                                 // Projects enabled but no active project | ||||
|                                 RED.menu.setDisabled('menu-item-projects-open',true); | ||||
|                                 RED.menu.setDisabled('menu-item-projects-settings',true); | ||||
|                                 if (activeProject === false) { | ||||
|                                     // User previously decline the migration to projects. | ||||
|                                 } else { // null/undefined | ||||
|                                     RED.projects.showStartup(); | ||||
|                                 } | ||||
|                             } | ||||
|                             completeLoad(); | ||||
|                         }); | ||||
|                     } else { | ||||
|                         // Projects disabled by the user | ||||
|                         RED.sidebar.info.refresh() | ||||
|                         completeLoad(); | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function loadFlows(done) { | ||||
|         $.ajax({ | ||||
|             headers: { | ||||
|                 "Accept":"application/json", | ||||
|             }, | ||||
|             cache: false, | ||||
|             url: 'flows', | ||||
|             success: function(nodes) { | ||||
|                 if (nodes) { | ||||
|                     var currentHash = window.location.hash; | ||||
|                     RED.nodes.version(nodes.rev); | ||||
|                     RED.nodes.import(nodes.flows); | ||||
|                     RED.nodes.dirty(false); | ||||
|                     RED.view.redraw(true); | ||||
|                     if (/^#flow\/.+$/.test(currentHash)) { | ||||
|                         RED.workspaces.show(currentHash.substring(6)); | ||||
|                     } | ||||
|                 } | ||||
|                 done(); | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function completeLoad() { | ||||
|         var persistentNotifications = {}; | ||||
|         RED.comms.subscribe("notification/#",function(topic,msg) { | ||||
|             var parts = topic.split("/"); | ||||
|             var notificationId = parts[1]; | ||||
|             if (notificationId === "runtime-deploy") { | ||||
|                 // handled in ui/deploy.js | ||||
|                 return; | ||||
|             } | ||||
|             if (notificationId === "node") { | ||||
|                 // handled below | ||||
|                 return; | ||||
|             } | ||||
|             if (notificationId === "project-update") { | ||||
|                 RED.nodes.clear(); | ||||
|                 RED.history.clear(); | ||||
|                 RED.view.redraw(true); | ||||
|                 RED.projects.refresh(function() { | ||||
|                     loadFlows(function() { | ||||
|                         var project = RED.projects.getActiveProject(); | ||||
|                         var message = { | ||||
|                             "change-branch":"Change to local branch '"+project.git.branches.local+"'", | ||||
|                             "merge-abort":"Git merge aborted", | ||||
|                             "loaded":"Project '"+msg.project+"' loaded", | ||||
|                             "updated":"Project '"+msg.project+"' updated", | ||||
|                             "pull":"Project '"+msg.project+"' reloaded", | ||||
|                             "revert": "Project '"+msg.project+"' reloaded", | ||||
|                             "merge-complete":"Git merge completed" | ||||
|                         }[msg.action]; | ||||
|                         RED.notify("<p>"+message+"</p>"); | ||||
|                         RED.sidebar.info.refresh() | ||||
|                     }); | ||||
|                 }); | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             if (msg.text) { | ||||
|                 msg.default = msg.text; | ||||
|                 var text = RED._(msg.text,msg); | ||||
|                 var options = { | ||||
|                     type: msg.type, | ||||
|                     fixed: msg.timeout === undefined, | ||||
|                     timeout: msg.timeout, | ||||
|                     id: notificationId | ||||
|                 } | ||||
|                 if (notificationId === "runtime-state") { | ||||
|                     if (msg.error === "missing-types") { | ||||
|                         text+="<ul><li>"+msg.types.join("</li><li>")+"</li></ul>"; | ||||
|                         if (!!RED.projects.getActiveProject()) { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "Manage project dependencies", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                         RED.projects.settings.show('deps'); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         // } else if (RED.settings.theme('palette.editable') !== false) { | ||||
|                         } else { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "Close", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         } | ||||
|                     } else if (msg.error === "credentials_load_failed") { | ||||
|                         if (RED.settings.theme("projects.enabled",false)) { | ||||
|                             // projects enabled | ||||
|                             if (RED.user.hasPermission("projects.write")) { | ||||
|                                 options.buttons = [ | ||||
|                                     { | ||||
|                                         text: "Setup credentials", | ||||
|                                         click: function() { | ||||
|                                             persistentNotifications[notificationId].hideNotification(); | ||||
|                                             RED.projects.showCredentialsPrompt(); | ||||
|                                         } | ||||
|                                     } | ||||
|                                 ] | ||||
|                             } | ||||
|                         } else { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "Close", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         } | ||||
|                     } else if (msg.error === "missing_flow_file") { | ||||
|                         if (RED.user.hasPermission("projects.write")) { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "Setup project files", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                         RED.projects.showFilesPrompt(); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         } | ||||
|                     } else if (msg.error === "missing_package_file") { | ||||
|                         if (RED.user.hasPermission("projects.write")) { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "Create default package file", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                         RED.projects.createDefaultPackageFile(); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         } | ||||
|                     } else if (msg.error === "project_empty") { | ||||
|                         if (RED.user.hasPermission("projects.write")) { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "No thanks", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                     } | ||||
|                                 }, | ||||
|                                 { | ||||
|                                     text: "Create default project files", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                         RED.projects.createDefaultFileSet(); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         } | ||||
|                     } else if (msg.error === "git_merge_conflict") { | ||||
|                         RED.nodes.clear(); | ||||
|                         RED.sidebar.versionControl.refresh(true); | ||||
|                         if (RED.user.hasPermission("projects.write")) { | ||||
|                             options.buttons = [ | ||||
|                                 { | ||||
|                                     text: "Show merge conflicts", | ||||
|                                     click: function() { | ||||
|                                         persistentNotifications[notificationId].hideNotification(); | ||||
|                                         RED.sidebar.versionControl.showLocalChanges(); | ||||
|                                     } | ||||
|                                 } | ||||
|                             ] | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 if (!persistentNotifications.hasOwnProperty(notificationId)) { | ||||
|                     persistentNotifications[notificationId] = RED.notify(text,options); | ||||
|                 } else { | ||||
|                     persistentNotifications[notificationId].update(text,options); | ||||
|                 } | ||||
|             } else if (persistentNotifications.hasOwnProperty(notificationId)) { | ||||
|                 persistentNotifications[notificationId].close(); | ||||
|                 delete persistentNotifications[notificationId]; | ||||
|             } | ||||
|         }); | ||||
|         RED.comms.subscribe("status/#",function(topic,msg) { | ||||
|             var parts = topic.split("/"); | ||||
|             var node = RED.nodes.node(parts[1]); | ||||
|             if (node) { | ||||
|                 if (msg.hasOwnProperty("text")) { | ||||
|                     if (msg.text[0] !== ".") { | ||||
|                         msg.text = node._(msg.text.toString(),{defaultValue:msg.text.toString()}); | ||||
|                     } | ||||
|                 } | ||||
|                 node.status = msg; | ||||
|                 node.dirty = true; | ||||
|                 RED.view.redraw(); | ||||
|             } | ||||
|         }); | ||||
|         RED.comms.subscribe("notification/node/#",function(topic,msg) { | ||||
|             var i,m; | ||||
|             var typeList; | ||||
|             var info; | ||||
|             if (topic == "notification/node/added") { | ||||
|                 var addedTypes = []; | ||||
|                 msg.forEach(function(m) { | ||||
|                     var id = m.id; | ||||
|                     RED.nodes.addNodeSet(m); | ||||
|                     addedTypes = addedTypes.concat(m.types); | ||||
|                     RED.i18n.loadCatalog(id, function() { | ||||
|                         $.get('nodes/'+id, function(data) { | ||||
|                             $("body").append(data); | ||||
|                         }); | ||||
|                     }); | ||||
|                 }); | ||||
|                 if (addedTypes.length) { | ||||
|                     typeList = "<ul><li>"+addedTypes.join("</li><li>")+"</li></ul>"; | ||||
|                     RED.notify(RED._("palette.event.nodeAdded", {count:addedTypes.length})+typeList,"success"); | ||||
|                 } | ||||
|                 loadIconList(); | ||||
|             } else if (topic == "notification/node/removed") { | ||||
|                 for (i=0;i<msg.length;i++) { | ||||
|                     m = msg[i]; | ||||
|                     info = RED.nodes.removeNodeSet(m.id); | ||||
|                     if (info.added) { | ||||
|                         typeList = "<ul><li>"+m.types.join("</li><li>")+"</li></ul>"; | ||||
|                         RED.notify(RED._("palette.event.nodeRemoved", {count:m.types.length})+typeList,"success"); | ||||
|                     } | ||||
|                 } | ||||
|                 loadIconList(); | ||||
|             } else if (topic == "notification/node/enabled") { | ||||
|                 if (msg.types) { | ||||
|                     info = RED.nodes.getNodeSet(msg.id); | ||||
|                     if (info.added) { | ||||
|                         RED.nodes.enableNodeSet(msg.id); | ||||
|                         typeList = "<ul><li>"+msg.types.join("</li><li>")+"</li></ul>"; | ||||
|                         RED.notify(RED._("palette.event.nodeEnabled", {count:msg.types.length})+typeList,"success"); | ||||
|                     } else { | ||||
|                         $.get('nodes/'+msg.id, function(data) { | ||||
|                             $("body").append(data); | ||||
|                             typeList = "<ul><li>"+msg.types.join("</li><li>")+"</li></ul>"; | ||||
|                             RED.notify(RED._("palette.event.nodeAdded", {count:msg.types.length})+typeList,"success"); | ||||
|                         }); | ||||
|                     } | ||||
|                 } | ||||
|             } else if (topic == "notification/node/disabled") { | ||||
|                 if (msg.types) { | ||||
|                     RED.nodes.disableNodeSet(msg.id); | ||||
|                     typeList = "<ul><li>"+msg.types.join("</li><li>")+"</li></ul>"; | ||||
|                     RED.notify(RED._("palette.event.nodeDisabled", {count:msg.types.length})+typeList,"success"); | ||||
|                 } | ||||
|             } else if (topic == "node/upgraded") { | ||||
|                 RED.notify(RED._("palette.event.nodeUpgraded", {module:msg.module,version:msg.version}),"success"); | ||||
|                 RED.nodes.registry.setModulePendingUpdated(msg.module,msg.version); | ||||
|             } | ||||
|             // Refresh flow library to ensure any examples are updated | ||||
|             RED.library.loadFlowLibrary(); | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function showAbout() { | ||||
|         $.get('red/about', function(data) { | ||||
|             var aboutHeader = '<div style="text-align:center;">'+ | ||||
|                                 '<img width="50px" src="red/images/node-red-icon.svg" />'+ | ||||
|                               '</div>'; | ||||
|  | ||||
|             RED.sidebar.info.set(aboutHeader+marked(data)); | ||||
|             RED.sidebar.info.show(); | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function loadEditor() { | ||||
|         var menuOptions = []; | ||||
|         if (RED.settings.theme("projects.enabled",false)) { | ||||
|             menuOptions.push({id:"menu-item-projects-menu",label:"Projects",options:[ | ||||
|                 {id:"menu-item-projects-new",label:"New",disabled:false,onselect:"core:new-project"}, | ||||
|                 {id:"menu-item-projects-open",label:"Open",disabled:false,onselect:"core:open-project"}, | ||||
|                 {id:"menu-item-projects-settings",label:"Project Settings",disabled:false,onselect:"core:show-project-settings"} | ||||
|             ]}); | ||||
|         } | ||||
|  | ||||
|  | ||||
|         menuOptions.push({id:"menu-item-view-menu",label:RED._("menu.label.view.view"),options:[ | ||||
|             // {id:"menu-item-view-show-grid",setting:"view-show-grid",label:RED._("menu.label.view.showGrid"),toggle:true,onselect:"core:toggle-show-grid"}, | ||||
|             // {id:"menu-item-view-snap-grid",setting:"view-snap-grid",label:RED._("menu.label.view.snapGrid"),toggle:true,onselect:"core:toggle-snap-grid"}, | ||||
|             // {id:"menu-item-status",setting:"node-show-status",label:RED._("menu.label.displayStatus"),toggle:true,onselect:"core:toggle-status", selected: true}, | ||||
|             //null, | ||||
|             // {id:"menu-item-bidi",label:RED._("menu.label.view.textDir"),options:[ | ||||
|             //     {id:"menu-item-bidi-default",toggle:"text-direction",label:RED._("menu.label.view.defaultDir"),selected: true, onselect:function(s) { if(s){RED.text.bidi.setTextDirection("")}}}, | ||||
|             //     {id:"menu-item-bidi-ltr",toggle:"text-direction",label:RED._("menu.label.view.ltr"), onselect:function(s) { if(s){RED.text.bidi.setTextDirection("ltr")}}}, | ||||
|             //     {id:"menu-item-bidi-rtl",toggle:"text-direction",label:RED._("menu.label.view.rtl"), onselect:function(s) { if(s){RED.text.bidi.setTextDirection("rtl")}}}, | ||||
|             //     {id:"menu-item-bidi-auto",toggle:"text-direction",label:RED._("menu.label.view.auto"), onselect:function(s) { if(s){RED.text.bidi.setTextDirection("auto")}}} | ||||
|             // ]}, | ||||
|             // null, | ||||
|             {id:"menu-item-sidebar",label:RED._("menu.label.sidebar.show"),toggle:true,onselect:"core:toggle-sidebar", selected: true}, | ||||
|             null | ||||
|         ]}); | ||||
|         menuOptions.push(null); | ||||
|         menuOptions.push({id:"menu-item-import",label:RED._("menu.label.import"),options:[ | ||||
|             {id:"menu-item-import-clipboard",label:RED._("menu.label.clipboard"),onselect:"core:show-import-dialog"}, | ||||
|             {id:"menu-item-import-library",label:RED._("menu.label.library"),options:[]} | ||||
|         ]}); | ||||
|         menuOptions.push({id:"menu-item-export",label:RED._("menu.label.export"),disabled:true,options:[ | ||||
|             {id:"menu-item-export-clipboard",label:RED._("menu.label.clipboard"),disabled:true,onselect:"core:show-export-dialog"}, | ||||
|             {id:"menu-item-export-library",label:RED._("menu.label.library"),disabled:true,onselect:"core:library-export"} | ||||
|         ]}); | ||||
|         menuOptions.push(null); | ||||
|         menuOptions.push({id:"menu-item-search",label:RED._("menu.label.search"),onselect:"core:search"}); | ||||
|         menuOptions.push(null); | ||||
|         menuOptions.push({id:"menu-item-config-nodes",label:RED._("menu.label.displayConfig"),onselect:"core:show-config-tab"}); | ||||
|         menuOptions.push({id:"menu-item-workspace",label:RED._("menu.label.flows"),options:[ | ||||
|             {id:"menu-item-workspace-add",label:RED._("menu.label.add"),onselect:"core:add-flow"}, | ||||
|             {id:"menu-item-workspace-edit",label:RED._("menu.label.rename"),onselect:"core:edit-flow"}, | ||||
|             {id:"menu-item-workspace-delete",label:RED._("menu.label.delete"),onselect:"core:remove-flow"} | ||||
|         ]}); | ||||
|         menuOptions.push({id:"menu-item-subflow",label:RED._("menu.label.subflows"), options: [ | ||||
|             {id:"menu-item-subflow-create",label:RED._("menu.label.createSubflow"),onselect:"core:create-subflow"}, | ||||
|             {id:"menu-item-subflow-convert",label:RED._("menu.label.selectionToSubflow"),disabled:true,onselect:"core:convert-to-subflow"}, | ||||
|         ]}); | ||||
|         menuOptions.push(null); | ||||
|         if (RED.settings.theme('palette.editable') !== false) { | ||||
|             menuOptions.push({id:"menu-item-edit-palette",label:RED._("menu.label.editPalette"),onselect:"core:manage-palette"}); | ||||
|             menuOptions.push(null); | ||||
|         } | ||||
|  | ||||
|         menuOptions.push({id:"menu-item-user-settings",label:RED._("menu.label.settings"),onselect:"core:show-user-settings"}); | ||||
|         menuOptions.push(null); | ||||
|  | ||||
|         menuOptions.push({id:"menu-item-keyboard-shortcuts",label:RED._("menu.label.keyboardShortcuts"),onselect:"core:show-help"}); | ||||
|         menuOptions.push({id:"menu-item-help", | ||||
|             label: RED.settings.theme("menu.menu-item-help.label",RED._("menu.label.help")), | ||||
|             href: RED.settings.theme("menu.menu-item-help.url","http://nodered.org/docs") | ||||
|         }); | ||||
|         menuOptions.push({id:"menu-item-node-red-version", label:"v"+RED.settings.version, onselect: "core:show-about" }); | ||||
|  | ||||
|  | ||||
|         RED.view.init(); | ||||
|         RED.userSettings.init(); | ||||
|         RED.user.init(); | ||||
|         RED.library.init(); | ||||
|         RED.keyboard.init(); | ||||
|         RED.palette.init(); | ||||
|         if (RED.settings.theme('palette.editable') !== false) { | ||||
|             RED.palette.editor.init(); | ||||
|         } else { | ||||
|             console.log("Palette editor disabled"); | ||||
|         } | ||||
|  | ||||
|         RED.sidebar.init(); | ||||
|  | ||||
|         if (RED.settings.theme("projects.enabled",false)) { | ||||
|             RED.projects.init(); | ||||
|         } else { | ||||
|             console.log("Projects disabled"); | ||||
|         } | ||||
|  | ||||
|         RED.subflow.init(); | ||||
|         RED.workspaces.init(); | ||||
|         RED.clipboard.init(); | ||||
|         RED.search.init(); | ||||
|         RED.editor.init(); | ||||
|         RED.diff.init(); | ||||
|  | ||||
|         RED.menu.init({id:"btn-sidemenu",options: menuOptions}); | ||||
|  | ||||
|         RED.deploy.init(RED.settings.theme("deployButton",null)); | ||||
|         RED.notifications.init(); | ||||
|  | ||||
|         RED.actions.add("core:show-about", showAbout); | ||||
|         RED.nodes.init(); | ||||
|         RED.comms.connect(); | ||||
|  | ||||
|         $("#main-container").show(); | ||||
|         $(".header-toolbar").show(); | ||||
|  | ||||
|         loadNodeList(); | ||||
|     } | ||||
|  | ||||
|     $(function() { | ||||
|  | ||||
|         if ((window.location.hostname !== "localhost") && (window.location.hostname !== "127.0.0.1")) { | ||||
|             document.title = document.title+" : "+window.location.hostname; | ||||
|         } | ||||
|  | ||||
|         ace.require("ace/ext/language_tools"); | ||||
|  | ||||
|         RED.i18n.init(function() { | ||||
|             RED.settings.init(loadEditor); | ||||
|         }) | ||||
|     }); | ||||
| })(); | ||||
							
								
								
									
										1403
									
								
								editor/js/nodes.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										16
									
								
								editor/js/red.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,16 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| var RED = {}; | ||||
							
								
								
									
										213
									
								
								editor/js/settings.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,213 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
|  | ||||
| RED.settings = (function () { | ||||
|  | ||||
|     var loadedSettings = {}; | ||||
|     var userSettings = {}; | ||||
|     var settingsDirty = false; | ||||
|     var pendingSave; | ||||
|  | ||||
|     var hasLocalStorage = function () { | ||||
|         try { | ||||
|             return 'localStorage' in window && window['localStorage'] !== null; | ||||
|         } catch (e) { | ||||
|             return false; | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     var set = function (key, value) { | ||||
|         if (!hasLocalStorage()) { | ||||
|             return; | ||||
|         } | ||||
|         if (key === "auth-tokens") { | ||||
|             localStorage.setItem(key, JSON.stringify(value)); | ||||
|         } else { | ||||
|             userSettings[key] = value; | ||||
|             saveUserSettings(); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * If the key is not set in the localStorage it returns <i>undefined</i> | ||||
|      * Else return the JSON parsed value | ||||
|      * @param key | ||||
|      * @returns {*} | ||||
|      */ | ||||
|     var get = function (key) { | ||||
|         if (!hasLocalStorage()) { | ||||
|             return undefined; | ||||
|         } | ||||
|         if (key === "auth-tokens") { | ||||
|             return JSON.parse(localStorage.getItem(key)); | ||||
|         } else { | ||||
|             return userSettings[key]; | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     var remove = function (key) { | ||||
|         if (!hasLocalStorage()) { | ||||
|             return; | ||||
|         } | ||||
|         if (key === "auth-tokens") { | ||||
|             localStorage.removeItem(key); | ||||
|         } else { | ||||
|             delete userSettings[key]; | ||||
|             saveUserSettings(); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|     var setProperties = function(data) { | ||||
|         for (var prop in loadedSettings) { | ||||
|             if (loadedSettings.hasOwnProperty(prop) && RED.settings.hasOwnProperty(prop)) { | ||||
|                 delete RED.settings[prop]; | ||||
|             } | ||||
|         } | ||||
|         for (prop in data) { | ||||
|             if (data.hasOwnProperty(prop)) { | ||||
|                 RED.settings[prop] = data[prop]; | ||||
|             } | ||||
|         } | ||||
|         loadedSettings = data; | ||||
|     }; | ||||
|  | ||||
|     var setUserSettings = function(data) { | ||||
|         userSettings = data; | ||||
|     } | ||||
|  | ||||
|     var init = function (done) { | ||||
|         var accessTokenMatch = /[?&]access_token=(.*?)(?:$|&)/.exec(window.location.search); | ||||
|         if (accessTokenMatch) { | ||||
|             var accessToken = accessTokenMatch[1]; | ||||
|             RED.settings.set("auth-tokens",{access_token: accessToken}); | ||||
|             window.location.search = ""; | ||||
|         } | ||||
|  | ||||
|         $.ajaxSetup({ | ||||
|             beforeSend: function(jqXHR,settings) { | ||||
|                 // Only attach auth header for requests to relative paths | ||||
|                 if (!/^\s*(https?:|\/|\.)/.test(settings.url)) { | ||||
|                     var auth_tokens = RED.settings.get("auth-tokens"); | ||||
|                     if (auth_tokens) { | ||||
|                         jqXHR.setRequestHeader("Authorization","Bearer "+auth_tokens.access_token); | ||||
|                     } | ||||
|                     jqXHR.setRequestHeader("Node-RED-API-Version","v2"); | ||||
|                 } | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         load(done); | ||||
|     } | ||||
|  | ||||
|     var load = function(done) { | ||||
|         $.ajax({ | ||||
|             headers: { | ||||
|                 "Accept": "application/json" | ||||
|             }, | ||||
|             dataType: "json", | ||||
|             cache: false, | ||||
|             url: 'settings', | ||||
|             success: function (data) { | ||||
|                 setProperties(data); | ||||
|                 if (!RED.settings.user || RED.settings.user.anonymous) { | ||||
|                     RED.settings.remove("auth-tokens"); | ||||
|                 } | ||||
|                 console.log("Node-RED: " + data.version); | ||||
|                 loadUserSettings(done); | ||||
|             }, | ||||
|             error: function(jqXHR,textStatus,errorThrown) { | ||||
|                 if (jqXHR.status === 401) { | ||||
|                     if (/[?&]access_token=(.*?)(?:$|&)/.test(window.location.search)) { | ||||
|                         window.location.search = ""; | ||||
|                     } | ||||
|                     RED.user.login(function() { load(done); }); | ||||
|                 } else { | ||||
|                     console.log("Unexpected error loading settings:",jqXHR.status,textStatus); | ||||
|                 } | ||||
|             } | ||||
|         }); | ||||
|     }; | ||||
|  | ||||
|     function loadUserSettings(done) { | ||||
|         $.ajax({ | ||||
|             headers: { | ||||
|                 "Accept": "application/json" | ||||
|             }, | ||||
|             dataType: "json", | ||||
|             cache: false, | ||||
|             url: 'settings/user', | ||||
|             success: function (data) { | ||||
|                 setUserSettings(data); | ||||
|                 done(); | ||||
|             }, | ||||
|             error: function(jqXHR,textStatus,errorThrown) { | ||||
|                 console.log("Unexpected error loading user settings:",jqXHR.status,textStatus); | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     function saveUserSettings() { | ||||
|         if (RED.user.hasPermission("settings.write")) { | ||||
|             if (pendingSave) { | ||||
|                 clearTimeout(pendingSave); | ||||
|             } | ||||
|             pendingSave = setTimeout(function() { | ||||
|                 pendingSave = null; | ||||
|                 $.ajax({ | ||||
|                     method: 'POST', | ||||
|                     contentType: 'application/json', | ||||
|                     url: 'settings/user', | ||||
|                     data: JSON.stringify(userSettings), | ||||
|                     success: function (data) { | ||||
|                     }, | ||||
|                     error: function(jqXHR,textStatus,errorThrown) { | ||||
|                         console.log("Unexpected error saving user settings:",jqXHR.status,textStatus); | ||||
|                     } | ||||
|                 }); | ||||
|             },300); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function theme(property,defaultValue) { | ||||
|         if (!RED.settings.editorTheme) { | ||||
|             return defaultValue; | ||||
|         } | ||||
|         var parts = property.split("."); | ||||
|         var v = RED.settings.editorTheme; | ||||
|         try { | ||||
|             for (var i=0;i<parts.length;i++) { | ||||
|                 v = v[parts[i]]; | ||||
|             } | ||||
|             if (v === undefined) { | ||||
|                 return defaultValue; | ||||
|             } | ||||
|             return v; | ||||
|         } catch(err) { | ||||
|             return defaultValue; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return { | ||||
|         init: init, | ||||
|         load: load, | ||||
|         loadUserSettings: loadUserSettings, | ||||
|         set: set, | ||||
|         get: get, | ||||
|         remove: remove, | ||||
|         theme: theme | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										130
									
								
								editor/js/text/bidi.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,130 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| RED.text = {}; | ||||
| RED.text.bidi = (function() { | ||||
|     var textDir = ""; | ||||
|     var LRE = "\u202A", | ||||
|         RLE = "\u202B", | ||||
|         PDF = "\u202C"; | ||||
|  | ||||
|     function isRTLValue(stringValue) { | ||||
|         var length = stringValue.length; | ||||
|         for (var i=0;i<length;i++) { | ||||
|             if (isBidiChar(stringValue.charCodeAt(i))) { | ||||
|                 return true; | ||||
|             } | ||||
|             else if(isLatinChar(stringValue.charCodeAt(i))) { | ||||
|                 return false; | ||||
|             } | ||||
|          } | ||||
|          return false; | ||||
|     } | ||||
|  | ||||
|     function isBidiChar(c)  { | ||||
|         return (c >= 0x05d0 && c <= 0x05ff)|| | ||||
|                (c >= 0x0600 && c <= 0x065f)|| | ||||
|                (c >= 0x066a && c <= 0x06ef)|| | ||||
|                (c >= 0x06fa && c <= 0x07ff)|| | ||||
|                (c >= 0xfb1d && c <= 0xfdff)|| | ||||
|                (c >= 0xfe70 && c <= 0xfefc); | ||||
|     } | ||||
|  | ||||
|     function isLatinChar(c){ | ||||
|         return (c > 64 && c < 91)||(c > 96 && c < 123) | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determines the text direction of a given string. | ||||
|      * @param value - the string | ||||
|      */ | ||||
|     function resolveBaseTextDir(value) { | ||||
|         if (textDir == "auto") { | ||||
|             if (isRTLValue(value)) { | ||||
|                 return "rtl"; | ||||
|             } else { | ||||
|                 return "ltr"; | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             return textDir; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function onInputChange() { | ||||
|         $(this).attr("dir", resolveBaseTextDir($(this).val())); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Adds event listeners to the Input to ensure its text-direction attribute | ||||
|      * is properly set based on its content. | ||||
|      * @param input - the input field | ||||
|      */ | ||||
|     function prepareInput(input) { | ||||
|         input.on("keyup",onInputChange).on("paste",onInputChange).on("cut",onInputChange); | ||||
|         // Set the initial text direction | ||||
|         onInputChange.call(input); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Enforces the text direction of a given string by adding | ||||
|      * UCC (Unicode Control Characters) | ||||
|      * @param value - the string | ||||
|      */ | ||||
|     function enforceTextDirectionWithUCC(value) { | ||||
|         if (value) { | ||||
|             var dir = resolveBaseTextDir(value); | ||||
|             if (dir == "ltr") { | ||||
|                return LRE + value + PDF; | ||||
|             } | ||||
|             else if (dir == "rtl") { | ||||
|                return RLE + value + PDF; | ||||
|             } | ||||
|         } | ||||
|         return value; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Enforces the text direction for all the spans with style bidiAware under | ||||
|      * workspace or sidebar div | ||||
|      */ | ||||
|     function enforceTextDirectionOnPage() { | ||||
|         $("#workspace").find('span.bidiAware').each(function() { | ||||
|             $(this).attr("dir", resolveBaseTextDir($(this).html())); | ||||
|         }); | ||||
|         $("#sidebar").find('span.bidiAware').each(function() { | ||||
|             $(this).attr("dir", resolveBaseTextDir($(this).text())); | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sets the text direction preference | ||||
|      * @param dir - the text direction preference | ||||
|      */ | ||||
|     function setTextDirection(dir) { | ||||
|         textDir = dir; | ||||
|         RED.nodes.eachNode(function(n) { n.dirty = true;}); | ||||
|         RED.view.redraw(); | ||||
|         RED.palette.refresh(); | ||||
|         enforceTextDirectionOnPage(); | ||||
|     } | ||||
|  | ||||
|     return { | ||||
|         setTextDirection: setTextDirection, | ||||
|         enforceTextDirectionWithUCC: enforceTextDirectionWithUCC, | ||||
|         resolveBaseTextDir: resolveBaseTextDir, | ||||
|         prepareInput: prepareInput | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										1330
									
								
								editor/js/text/format.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										35
									
								
								editor/js/ui/actions.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,35 @@ | ||||
| RED.actions = (function() { | ||||
|     var actions = { | ||||
|  | ||||
|     } | ||||
|  | ||||
|     function addAction(name,handler) { | ||||
|         actions[name] = handler; | ||||
|     } | ||||
|     function removeAction(name) { | ||||
|         delete actions[name]; | ||||
|     } | ||||
|     function getAction(name) { | ||||
|         return actions[name]; | ||||
|     } | ||||
|     function invokeAction(name) { | ||||
|         if (actions.hasOwnProperty(name)) { | ||||
|             actions[name](); | ||||
|         } | ||||
|     } | ||||
|     function listActions() { | ||||
|         var result = []; | ||||
|         Object.keys(actions).forEach(function(action) { | ||||
|             var shortcut = RED.keyboard.getShortcut(action); | ||||
|             result.push({id:action,scope:shortcut?shortcut.scope:undefined,key:shortcut?shortcut.key:undefined,user:shortcut?shortcut.user:undefined}) | ||||
|         }) | ||||
|         return result; | ||||
|     } | ||||
|     return { | ||||
|         add: addAction, | ||||
|         remove: removeAction, | ||||
|         get: getAction, | ||||
|         invoke: invokeAction, | ||||
|         list: listActions | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										380
									
								
								editor/js/ui/clipboard.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,380 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
|  | ||||
| RED.clipboard = (function() { | ||||
|  | ||||
|     var dialog; | ||||
|     var dialogContainer; | ||||
|     var exportNodesDialog; | ||||
|     var importNodesDialog; | ||||
|     var disabled = false; | ||||
|  | ||||
|     function setupDialogs() { | ||||
|         dialog = $('<div id="clipboard-dialog" class="hide node-red-dialog"><form class="dialog-form form-horizontal"></form></div>') | ||||
|             .appendTo("body") | ||||
|             .dialog({ | ||||
|                 modal: true, | ||||
|                 autoOpen: false, | ||||
|                 width: 500, | ||||
|                 resizable: false, | ||||
|                 buttons: [ | ||||
|                     { | ||||
|                         id: "clipboard-dialog-cancel", | ||||
|                         text: RED._("common.label.cancel"), | ||||
|                         click: function() { | ||||
|                             $( this ).dialog( "close" ); | ||||
|                         } | ||||
|                     }, | ||||
|                     { | ||||
|                         id: "clipboard-dialog-close", | ||||
|                         class: "primary", | ||||
|                         text: RED._("common.label.close"), | ||||
|                         click: function() { | ||||
|                             $( this ).dialog( "close" ); | ||||
|                         } | ||||
|                     }, | ||||
|                     { | ||||
|                         id: "clipboard-dialog-copy", | ||||
|                         class: "primary", | ||||
|                         text: RED._("clipboard.export.copy"), | ||||
|                         click: function() { | ||||
|                             $("#clipboard-export").select(); | ||||
|                             document.execCommand("copy"); | ||||
|                             document.getSelection().removeAllRanges(); | ||||
|                             RED.notify(RED._("clipboard.nodesExported")); | ||||
|                             $( this ).dialog( "close" ); | ||||
|                         } | ||||
|                     }, | ||||
|                     { | ||||
|                         id: "clipboard-dialog-ok", | ||||
|                         class: "primary", | ||||
|                         text: RED._("common.label.import"), | ||||
|                         click: function() { | ||||
|                             RED.view.importNodes($("#clipboard-import").val(),$("#import-tab > a.selected").attr('id') === 'import-tab-new'); | ||||
|                             $( this ).dialog( "close" ); | ||||
|                         } | ||||
|                     } | ||||
|                 ], | ||||
|                 open: function(e) { | ||||
|                     $(this).parent().find(".ui-dialog-titlebar-close").hide(); | ||||
|                 }, | ||||
|                 close: function(e) { | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|         dialogContainer = dialog.children(".dialog-form"); | ||||
|  | ||||
|         exportNodesDialog = | ||||
|             '<div class="form-row">'+ | ||||
|                 '<label style="width:auto;margin-right: 10px;" data-i18n="clipboard.export.copy"></label>'+ | ||||
|                 '<span id="export-range-group" class="button-group">'+ | ||||
|                     '<a id="export-range-selected" class="editor-button toggle" href="#" data-i18n="clipboard.export.selected"></a>'+ | ||||
|                     '<a id="export-range-flow" class="editor-button toggle" href="#" data-i18n="clipboard.export.current"></a>'+ | ||||
|                     '<a id="export-range-full" class="editor-button toggle" href="#" data-i18n="clipboard.export.all"></a>'+ | ||||
|                 '</span>'+ | ||||
|                 '</div>'+ | ||||
|             '<div class="form-row">'+ | ||||
|                 '<textarea readonly style="resize: none; width: 100%; border-radius: 4px;font-family: monospace; font-size: 12px; background:#f3f3f3; padding-left: 0.5em; box-sizing:border-box;" id="clipboard-export" rows="5"></textarea>'+ | ||||
|             '</div>'+ | ||||
|             '<div class="form-row" style="text-align: right;">'+ | ||||
|                 '<span id="export-format-group" class="button-group">'+ | ||||
|                     '<a id="export-format-mini" class="editor-button editor-button-small toggle" href="#" data-i18n="clipboard.export.compact"></a>'+ | ||||
|                     '<a id="export-format-full" class="editor-button editor-button-small toggle" href="#" data-i18n="clipboard.export.formatted"></a>'+ | ||||
|                 '</span>'+ | ||||
|             '</div>'; | ||||
|  | ||||
|         importNodesDialog = '<div class="form-row">'+ | ||||
|             '<textarea style="resize: none; width: 100%; border-radius: 0px;font-family: monospace; font-size: 12px; background:#eee; padding-left: 0.5em; box-sizing:border-box;" id="clipboard-import" rows="5" placeholder="'+ | ||||
|             RED._("clipboard.pasteNodes")+ | ||||
|             '"></textarea>'+ | ||||
|             '</div>'+ | ||||
|             '<div class="form-row">'+ | ||||
|             '<label style="width:auto;margin-right: 10px;" data-i18n="clipboard.import.import"></label>'+ | ||||
|             '<span id="import-tab" class="button-group">'+ | ||||
|                 '<a id="import-tab-current" class="editor-button toggle selected" href="#" data-i18n="clipboard.export.current"></a>'+ | ||||
|                 '<a id="import-tab-new" class="editor-button toggle" href="#" data-i18n="clipboard.import.newFlow"></a>'+ | ||||
|             '</span>'+ | ||||
|             '</div>'; | ||||
|     } | ||||
|  | ||||
|     function validateImport() { | ||||
|         var importInput = $("#clipboard-import"); | ||||
|         var v = importInput.val(); | ||||
|         v = v.substring(v.indexOf('['),v.lastIndexOf(']')+1); | ||||
|         try { | ||||
|             JSON.parse(v); | ||||
|             importInput.removeClass("input-error"); | ||||
|             importInput.val(v); | ||||
|             $("#clipboard-dialog-ok").button("enable"); | ||||
|         } catch(err) { | ||||
|             if (v !== "") { | ||||
|                 importInput.addClass("input-error"); | ||||
|             } | ||||
|             $("#clipboard-dialog-ok").button("disable"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function importNodes() { | ||||
|         if (disabled) { | ||||
|             return; | ||||
|         } | ||||
|         dialogContainer.empty(); | ||||
|         dialogContainer.append($(importNodesDialog)); | ||||
|         dialogContainer.i18n(); | ||||
|  | ||||
|         $("#clipboard-dialog-ok").show(); | ||||
|         $("#clipboard-dialog-cancel").show(); | ||||
|         $("#clipboard-dialog-close").hide(); | ||||
|         $("#clipboard-dialog-copy").hide(); | ||||
|         $("#clipboard-dialog-ok").button("disable"); | ||||
|         $("#clipboard-import").keyup(validateImport); | ||||
|         $("#clipboard-import").on('paste',function() { setTimeout(validateImport,10)}); | ||||
|  | ||||
|         $("#import-tab > a").click(function(evt) { | ||||
|             evt.preventDefault(); | ||||
|             if ($(this).hasClass('disabled') || $(this).hasClass('selected')) { | ||||
|                 return; | ||||
|             } | ||||
|             $(this).parent().children().removeClass('selected'); | ||||
|             $(this).addClass('selected'); | ||||
|         }); | ||||
|  | ||||
|         dialog.dialog("option","title",RED._("clipboard.importNodes")).dialog("open"); | ||||
|     } | ||||
|  | ||||
|     function exportNodes() { | ||||
|         if (disabled) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         dialogContainer.empty(); | ||||
|         dialogContainer.append($(exportNodesDialog)); | ||||
|         dialogContainer.i18n(); | ||||
|         var format = RED.settings.flowFilePretty ? "export-format-full" : "export-format-mini"; | ||||
|  | ||||
|         $("#export-format-group > a").click(function(evt) { | ||||
|             evt.preventDefault(); | ||||
|             if ($(this).hasClass('disabled') || $(this).hasClass('selected')) { | ||||
|                 $("#clipboard-export").focus(); | ||||
|                 return; | ||||
|             } | ||||
|             $(this).parent().children().removeClass('selected'); | ||||
|             $(this).addClass('selected'); | ||||
|  | ||||
|             var flow = $("#clipboard-export").val(); | ||||
|             if (flow.length > 0) { | ||||
|                 var nodes = JSON.parse(flow); | ||||
|  | ||||
|                 format = $(this).attr('id'); | ||||
|                 if (format === 'export-format-full') { | ||||
|                     flow = JSON.stringify(nodes,null,4); | ||||
|                 } else { | ||||
|                     flow = JSON.stringify(nodes); | ||||
|                 } | ||||
|                 $("#clipboard-export").val(flow); | ||||
|                 $("#clipboard-export").focus(); | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         $("#export-range-group > a").click(function(evt) { | ||||
|             evt.preventDefault(); | ||||
|             if ($(this).hasClass('disabled') || $(this).hasClass('selected')) { | ||||
|                 $("#clipboard-export").focus(); | ||||
|                 return; | ||||
|             } | ||||
|             $(this).parent().children().removeClass('selected'); | ||||
|             $(this).addClass('selected'); | ||||
|             var type = $(this).attr('id'); | ||||
|             var flow = ""; | ||||
|             var nodes = null; | ||||
|             if (type === 'export-range-selected') { | ||||
|                 var selection = RED.view.selection(); | ||||
|                 // Don't include the subflow meta-port nodes in the exported selection | ||||
|                 nodes = RED.nodes.createExportableNodeSet(selection.nodes.filter(function(n) { return n.type !== 'subflow'})); | ||||
|             } else if (type === 'export-range-flow') { | ||||
|                 var activeWorkspace = RED.workspaces.active(); | ||||
|                 nodes = RED.nodes.filterNodes({z:activeWorkspace}); | ||||
|                 var parentNode = RED.nodes.workspace(activeWorkspace)||RED.nodes.subflow(activeWorkspace); | ||||
|                 nodes.unshift(parentNode); | ||||
|                 nodes = RED.nodes.createExportableNodeSet(nodes); | ||||
|             } else if (type === 'export-range-full') { | ||||
|                 nodes = RED.nodes.createCompleteNodeSet(false); | ||||
|             } | ||||
|             if (nodes !== null) { | ||||
|                 if (format === "export-format-full") { | ||||
|                     flow = JSON.stringify(nodes,null,4); | ||||
|                 } else { | ||||
|                     flow = JSON.stringify(nodes); | ||||
|                 } | ||||
|             } | ||||
|             if (flow.length > 0) { | ||||
|                 $("#export-copy").removeClass('disabled'); | ||||
|             } else { | ||||
|                 $("#export-copy").addClass('disabled'); | ||||
|             } | ||||
|             $("#clipboard-export").val(flow); | ||||
|             $("#clipboard-export").focus(); | ||||
|         }) | ||||
|  | ||||
|         $("#clipboard-dialog-ok").hide(); | ||||
|         $("#clipboard-dialog-cancel").hide(); | ||||
|         $("#clipboard-dialog-copy").hide(); | ||||
|         $("#clipboard-dialog-close").hide(); | ||||
|         var selection = RED.view.selection(); | ||||
|         if (selection.nodes) { | ||||
|             $("#export-range-selected").click(); | ||||
|         } else { | ||||
|             $("#export-range-selected").addClass('disabled').removeClass('selected'); | ||||
|             $("#export-range-flow").click(); | ||||
|         } | ||||
|         if (format === "export-format-full") { | ||||
|             $("#export-format-full").click(); | ||||
|         } else { | ||||
|             $("#export-format-mini").click(); | ||||
|         } | ||||
|         $("#clipboard-export") | ||||
|             .focus(function() { | ||||
|                 var textarea = $(this); | ||||
|                 textarea.select(); | ||||
|                 textarea.mouseup(function() { | ||||
|                     textarea.unbind("mouseup"); | ||||
|                     return false; | ||||
|                 }) | ||||
|             }); | ||||
|         dialog.dialog("option","title",RED._("clipboard.exportNodes")).dialog( "open" ); | ||||
|  | ||||
|         $("#clipboard-export").focus(); | ||||
|         if (!document.queryCommandSupported("copy")) { | ||||
|             $("#clipboard-dialog-cancel").hide(); | ||||
|             $("#clipboard-dialog-close").show(); | ||||
|         } else { | ||||
|             $("#clipboard-dialog-cancel").show(); | ||||
|             $("#clipboard-dialog-copy").show(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function hideDropTarget() { | ||||
|         $("#dropTarget").hide(); | ||||
|         RED.keyboard.remove("escape"); | ||||
|     } | ||||
|     function copyText(value,element,msg) { | ||||
|         var truncated = false; | ||||
|         if (typeof value !== "string" ) { | ||||
|             value = JSON.stringify(value, function(key,value) { | ||||
|                 if (value !== null && typeof value === 'object') { | ||||
|                     if (value.__encoded__ && value.hasOwnProperty('data') && value.hasOwnProperty('length')) { | ||||
|                         truncated = value.data.length !== value.length; | ||||
|                         return value.data; | ||||
|                     } | ||||
|                 } | ||||
|                 return value; | ||||
|             }); | ||||
|         } | ||||
|         if (truncated) { | ||||
|             msg += "_truncated"; | ||||
|         } | ||||
|         $("#clipboard-hidden").val(value).select(); | ||||
|         var result =  document.execCommand("copy"); | ||||
|         if (result && element) { | ||||
|             var popover = RED.popover.create({ | ||||
|                 target: element, | ||||
|                 direction: 'left', | ||||
|                 size: 'small', | ||||
|                 content: RED._(msg) | ||||
|             }); | ||||
|             setTimeout(function() { | ||||
|                 popover.close(); | ||||
|             },1000); | ||||
|             popover.open(); | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
|     return { | ||||
|         init: function() { | ||||
|             setupDialogs(); | ||||
|  | ||||
|             $('<input type="text" id="clipboard-hidden">').appendTo("body"); | ||||
|  | ||||
|             RED.events.on("view:selection-changed",function(selection) { | ||||
|                 if (!selection.nodes) { | ||||
|                     RED.menu.setDisabled("menu-item-export",true); | ||||
|                     RED.menu.setDisabled("menu-item-export-clipboard",true); | ||||
|                     RED.menu.setDisabled("menu-item-export-library",true); | ||||
|                 } else { | ||||
|                     RED.menu.setDisabled("menu-item-export",false); | ||||
|                     RED.menu.setDisabled("menu-item-export-clipboard",false); | ||||
|                     RED.menu.setDisabled("menu-item-export-library",false); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             RED.actions.add("core:show-export-dialog",exportNodes); | ||||
|             RED.actions.add("core:show-import-dialog",importNodes); | ||||
|  | ||||
|  | ||||
|             RED.events.on("editor:open",function() { disabled = true; }); | ||||
|             RED.events.on("editor:close",function() { disabled = false; }); | ||||
|             RED.events.on("search:open",function() { disabled = true; }); | ||||
|             RED.events.on("search:close",function() { disabled = false; }); | ||||
|             RED.events.on("type-search:open",function() { disabled = true; }); | ||||
|             RED.events.on("type-search:close",function() { disabled = false; }); | ||||
|  | ||||
|  | ||||
|             $('#chart').on("dragenter",function(event) { | ||||
|                 if ($.inArray("text/plain",event.originalEvent.dataTransfer.types) != -1 || | ||||
|                      $.inArray("Files",event.originalEvent.dataTransfer.types) != -1) { | ||||
|                     $("#dropTarget").css({display:'table'}); | ||||
|                     RED.keyboard.add("*", "escape" ,hideDropTarget); | ||||
|                 } | ||||
|             }); | ||||
|  | ||||
|             $('#dropTarget').on("dragover",function(event) { | ||||
|                 if ($.inArray("text/plain",event.originalEvent.dataTransfer.types) != -1 || | ||||
|                      $.inArray("Files",event.originalEvent.dataTransfer.types) != -1) { | ||||
|                     event.preventDefault(); | ||||
|                 } | ||||
|             }) | ||||
|             .on("dragleave",function(event) { | ||||
|                 hideDropTarget(); | ||||
|             }) | ||||
|             .on("drop",function(event) { | ||||
|                 if ($.inArray("text/plain",event.originalEvent.dataTransfer.types) != -1) { | ||||
|                     var data = event.originalEvent.dataTransfer.getData("text/plain"); | ||||
|                     data = data.substring(data.indexOf('['),data.lastIndexOf(']')+1); | ||||
|                     RED.view.importNodes(data); | ||||
|                 } else if ($.inArray("Files",event.originalEvent.dataTransfer.types) != -1) { | ||||
|                     var files = event.originalEvent.dataTransfer.files; | ||||
|                     if (files.length === 1) { | ||||
|                         var file = files[0]; | ||||
|                         var reader = new FileReader(); | ||||
|                         reader.onload = (function(theFile) { | ||||
|                             return function(e) { | ||||
|                                 RED.view.importNodes(e.target.result); | ||||
|                             }; | ||||
|                         })(file); | ||||
|                         reader.readAsText(file); | ||||
|                     } | ||||
|                 } | ||||
|                 hideDropTarget(); | ||||
|                 event.preventDefault(); | ||||
|             }); | ||||
|  | ||||
|         }, | ||||
|         import: importNodes, | ||||
|         export: exportNodes, | ||||
|         copyText: copyText | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										131
									
								
								editor/js/ui/common/checkboxSet.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,131 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| (function($) { | ||||
|     $.widget( "nodered.checkboxSet", { | ||||
|         _create: function() { | ||||
|             var that = this; | ||||
|             this.uiElement = this.element.wrap( "<span>" ).parent(); | ||||
|             this.uiElement.addClass("red-ui-checkboxSet"); | ||||
|             if (this.options.parent) { | ||||
|                 this.parent = this.options.parent; | ||||
|                 this.parent.checkboxSet('addChild',this.element); | ||||
|             } | ||||
|             this.children = []; | ||||
|             this.partialFlag = false; | ||||
|             this.stateValue = 0; | ||||
|             var initialState = this.element.prop('checked'); | ||||
|             this.options = [ | ||||
|                 $('<span class="red-ui-checkboxSet-option hide"><i class="fa fa-square-o"></i></span>').appendTo(this.uiElement), | ||||
|                 $('<span class="red-ui-checkboxSet-option hide"><i class="fa fa-check-square-o"></i></span>').appendTo(this.uiElement), | ||||
|                 $('<span class="red-ui-checkboxSet-option hide"><i class="fa fa-minus-square-o"></i></span>').appendTo(this.uiElement) | ||||
|             ]; | ||||
|             if (initialState) { | ||||
|                 this.options[1].show(); | ||||
|             } else { | ||||
|                 this.options[0].show(); | ||||
|             } | ||||
|  | ||||
|             this.element.change(function() { | ||||
|                 if (this.checked) { | ||||
|                     that.options[0].hide(); | ||||
|                     that.options[1].show(); | ||||
|                     that.options[2].hide(); | ||||
|                 } else { | ||||
|                     that.options[1].hide(); | ||||
|                     that.options[0].show(); | ||||
|                     that.options[2].hide(); | ||||
|                 } | ||||
|                 var isChecked = this.checked; | ||||
|                 that.children.forEach(function(child) { | ||||
|                     child.checkboxSet('state',isChecked,false,true); | ||||
|                 }) | ||||
|             }) | ||||
|             this.uiElement.click(function(e) { | ||||
|                 e.stopPropagation(); | ||||
|                 // state returns null for a partial state. Clicking on that should | ||||
|                 // result in false. | ||||
|                 that.state((that.state()===false)?true:false); | ||||
|             }) | ||||
|             if (this.parent) { | ||||
|                 this.parent.checkboxSet('updateChild',this); | ||||
|             } | ||||
|         }, | ||||
|         _destroy: function() { | ||||
|             if (this.parent) { | ||||
|                 this.parent.checkboxSet('removeChild',this.element); | ||||
|             } | ||||
|         }, | ||||
|         addChild: function(child) { | ||||
|             var that = this; | ||||
|             this.children.push(child); | ||||
|         }, | ||||
|         removeChild: function(child) { | ||||
|             var index = this.children.indexOf(child); | ||||
|             if (index > -1) { | ||||
|                 this.children.splice(index,1); | ||||
|             } | ||||
|         }, | ||||
|         updateChild: function(child) { | ||||
|             var checkedCount = 0; | ||||
|             this.children.forEach(function(c,i) { | ||||
|                 if (c.checkboxSet('state') === true) { | ||||
|                     checkedCount++; | ||||
|                 } | ||||
|             }); | ||||
|             if (checkedCount === 0) { | ||||
|  | ||||
|                 this.state(false,true); | ||||
|             } else if (checkedCount === this.children.length) { | ||||
|                 this.state(true,true); | ||||
|             } else { | ||||
|                 this.state(null,true); | ||||
|             } | ||||
|         }, | ||||
|         disable: function() { | ||||
|             this.uiElement.addClass('disabled'); | ||||
|         }, | ||||
|         state: function(state,suppressEvent,suppressParentUpdate) { | ||||
|  | ||||
|             if (arguments.length === 0) { | ||||
|                 return this.partialFlag?null:this.element.is(":checked"); | ||||
|             } else { | ||||
|                 this.partialFlag = (state === null); | ||||
|                 var trueState = this.partialFlag||state; | ||||
|                 this.element.prop('checked',trueState); | ||||
|                 if (state === true) { | ||||
|                     this.options[0].hide(); | ||||
|                     this.options[1].show(); | ||||
|                     this.options[2].hide(); | ||||
|                 } else if (state === false) { | ||||
|                     this.options[2].hide(); | ||||
|                     this.options[1].hide(); | ||||
|                     this.options[0].show(); | ||||
|                 } else if (state === null) { | ||||
|                     this.options[0].hide(); | ||||
|                     this.options[1].hide(); | ||||
|                     this.options[2].show(); | ||||
|                 } | ||||
|                 if (!suppressEvent) { | ||||
|                     this.element.trigger('change',null); | ||||
|                 } | ||||
|                 if (!suppressParentUpdate && this.parent) { | ||||
|                     this.parent.checkboxSet('updateChild',this); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     }) | ||||
|  | ||||
| })(jQuery); | ||||
							
								
								
									
										332
									
								
								editor/js/ui/common/editableList.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,332 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| (function($) { | ||||
|  | ||||
| /** | ||||
|  * options: | ||||
|  *   - addButton : boolean|string - text for add label, default 'add' | ||||
|  *   - height : number|'auto' | ||||
|  *   - resize : function - called when list as a whole is resized | ||||
|  *   - resizeItem : function(item) - called to resize individual item | ||||
|  *   - sortable : boolean|string - string is the css selector for handle | ||||
|  *   - sortItems : function(items) - when order of items changes | ||||
|  *   - connectWith : css selector of other sortables | ||||
|  *   - removable : boolean - whether to display delete button on items | ||||
|  *   - addItem : function(row,index,itemData) - when an item is added | ||||
|  *   - removeItem : function(itemData) - called when an item is removed | ||||
|  *   - filter : function(itemData) - called for each item to determine if it should be shown | ||||
|  *   - sort : function(itemDataA,itemDataB) - called to sort items | ||||
|  *   - scrollOnAdd : boolean - whether to scroll to newly added items | ||||
|  * methods: | ||||
|  *   - addItem(itemData) | ||||
|  *   - removeItem(itemData) | ||||
|  *   - width(width) | ||||
|  *   - height(height) | ||||
|  *   - items() | ||||
|  *   - empty() | ||||
|  *   - filter(filter) | ||||
|  *   - sort(sort) | ||||
|  *   - length() | ||||
|  */ | ||||
|     $.widget( "nodered.editableList", { | ||||
|         _create: function() { | ||||
|             var that = this; | ||||
|  | ||||
|             this.element.addClass('red-ui-editableList-list'); | ||||
|             this.uiWidth = this.element.width(); | ||||
|             this.uiContainer = this.element | ||||
|                 .wrap( "<div>" ) | ||||
|                 .parent(); | ||||
|  | ||||
|             if (this.options.header) { | ||||
|                 this.options.header.addClass("red-ui-editableList-header"); | ||||
|                 this.borderContainer = this.uiContainer.wrap("<div>").parent(); | ||||
|                 this.borderContainer.prepend(this.options.header); | ||||
|                 this.topContainer = this.borderContainer.wrap("<div>").parent(); | ||||
|             } else { | ||||
|                 this.topContainer = this.uiContainer.wrap("<div>").parent(); | ||||
|             } | ||||
|             this.topContainer.addClass('red-ui-editableList'); | ||||
|             if (this.options.class) { | ||||
|                 this.topContainer.addClass(this.options.class); | ||||
|             } | ||||
|  | ||||
|             if (this.options.addButton !== false) { | ||||
|                 var addLabel; | ||||
|                 if (typeof this.options.addButton === 'string') { | ||||
|                     addLabel = this.options.addButton | ||||
|                 } else { | ||||
|                     if (RED && RED._) { | ||||
|                         addLabel = RED._("editableList.add"); | ||||
|                     } else { | ||||
|                         addLabel = 'add'; | ||||
|                     } | ||||
|                 } | ||||
|                 $('<a href="#" class="editor-button editor-button-small red-ui-editableList-addButton" style="margin-top: 4px;"><i class="fa fa-plus"></i> '+addLabel+'</a>') | ||||
|                     .appendTo(this.topContainer) | ||||
|                     .click(function(evt) { | ||||
|                         evt.preventDefault(); | ||||
|                         that.addItem({}); | ||||
|                     }); | ||||
|             } | ||||
|             if (this.element.css("position") === "absolute") { | ||||
|                 ["top","left","bottom","right"].forEach(function(s) { | ||||
|                     var v = that.element.css(s); | ||||
|                     if (v!=="auto" && v!=="") { | ||||
|                         that.topContainer.css(s,v); | ||||
|                         that.uiContainer.css(s,"0"); | ||||
|                         that.element.css(s,'auto'); | ||||
|                     } | ||||
|                 }) | ||||
|                 this.element.css("position","static"); | ||||
|                 this.topContainer.css("position","absolute"); | ||||
|                 this.uiContainer.css("position","absolute"); | ||||
|  | ||||
|             } | ||||
|             if (this.options.header) { | ||||
|                 this.borderContainer.addClass("red-ui-editableList-border"); | ||||
|             } else { | ||||
|                 this.uiContainer.addClass("red-ui-editableList-border"); | ||||
|             } | ||||
|             this.uiContainer.addClass("red-ui-editableList-container"); | ||||
|  | ||||
|             this.uiHeight = this.element.height(); | ||||
|  | ||||
|             this.activeFilter = this.options.filter||null; | ||||
|             this.activeSort = this.options.sort||null; | ||||
|             this.scrollOnAdd = this.options.scrollOnAdd; | ||||
|             if (this.scrollOnAdd === undefined) { | ||||
|                 this.scrollOnAdd = true; | ||||
|             } | ||||
|             var minHeight = this.element.css("minHeight"); | ||||
|             if (minHeight !== '0px') { | ||||
|                 this.uiContainer.css("minHeight",minHeight); | ||||
|                 this.element.css("minHeight",0); | ||||
|             } | ||||
|             var maxHeight = this.element.css("maxHeight"); | ||||
|             if (maxHeight !== '0px') { | ||||
|                 this.uiContainer.css("maxHeight",maxHeight); | ||||
|                 this.element.css("maxHeight",null); | ||||
|             } | ||||
|             if (this.options.height !== 'auto') { | ||||
|                 this.uiContainer.css("overflow-y","scroll"); | ||||
|                 if (!isNaN(this.options.height)) { | ||||
|                     this.uiHeight = this.options.height; | ||||
|                 } | ||||
|             } | ||||
|             this.element.height('auto'); | ||||
|  | ||||
|             var attrStyle = this.element.attr('style'); | ||||
|             var m; | ||||
|             if ((m = /width\s*:\s*(\d+%)/i.exec(attrStyle)) !== null) { | ||||
|                 this.element.width('100%'); | ||||
|                 this.uiContainer.width(m[1]); | ||||
|             } | ||||
|             if (this.options.sortable) { | ||||
|                 var handle = (typeof this.options.sortable === 'string')? | ||||
|                                 this.options.sortable : | ||||
|                                 ".red-ui-editableList-item-handle"; | ||||
|                 var sortOptions = { | ||||
|                     axis: "y", | ||||
|                     update: function( event, ui ) { | ||||
|                         if (that.options.sortItems) { | ||||
|                             that.options.sortItems(that.items()); | ||||
|                         } | ||||
|                     }, | ||||
|                     handle:handle, | ||||
|                     cursor: "move", | ||||
|                     tolerance: "pointer", | ||||
|                     forcePlaceholderSize:true, | ||||
|                     placeholder: "red-ui-editabelList-item-placeholder", | ||||
|                     start: function(e, ui){ | ||||
|                         ui.placeholder.height(ui.item.height()-4); | ||||
|                     } | ||||
|                 }; | ||||
|                 if (this.options.connectWith) { | ||||
|                     sortOptions.connectWith = this.options.connectWith; | ||||
|                 } | ||||
|  | ||||
|                 this.element.sortable(sortOptions); | ||||
|             } | ||||
|  | ||||
|             this._resize(); | ||||
|  | ||||
|             // this.menu = this._createMenu(this.types, function(v) { that.type(v) }); | ||||
|             // this.type(this.options.default||this.types[0].value); | ||||
|         }, | ||||
|         _resize: function() { | ||||
|             var currentFullHeight = this.topContainer.height(); | ||||
|             var innerHeight = this.uiContainer.height(); | ||||
|             var delta = currentFullHeight - innerHeight; | ||||
|             if (this.uiHeight !== 0) { | ||||
|                 this.uiContainer.height(this.uiHeight-delta); | ||||
|             } | ||||
|             if (this.options.resize) { | ||||
|                 this.options.resize(); | ||||
|             } | ||||
|             if (this.options.resizeItem) { | ||||
|                 var that = this; | ||||
|                 this.element.children().each(function(i) { | ||||
|                     that.options.resizeItem($(this).find(".red-ui-editableList-item-content"),i); | ||||
|                 }); | ||||
|             } | ||||
|         }, | ||||
|         _destroy: function() { | ||||
|         }, | ||||
|         _refreshFilter: function() { | ||||
|             var that = this; | ||||
|             var count = 0; | ||||
|             if (!this.activeFilter) { | ||||
|                 return this.element.children().show(); | ||||
|             } | ||||
|             var items = this.items(); | ||||
|             items.each(function (i,el) { | ||||
|                 var data = el.data('data'); | ||||
|                 try { | ||||
|                     if (that.activeFilter(data)) { | ||||
|                         el.parent().show(); | ||||
|                         count++; | ||||
|                     } else { | ||||
|                         el.parent().hide(); | ||||
|                     } | ||||
|                 } catch(err) { | ||||
|                     console.log(err); | ||||
|                     el.parent().show(); | ||||
|                     count++; | ||||
|                 } | ||||
|             }); | ||||
|             return count; | ||||
|         }, | ||||
|         _refreshSort: function() { | ||||
|             if (this.activeSort) { | ||||
|                 var items = this.element.children(); | ||||
|                 var that = this; | ||||
|                 items.sort(function(A,B) { | ||||
|                     return that.activeSort($(A).find(".red-ui-editableList-item-content").data('data'),$(B).find(".red-ui-editableList-item-content").data('data')); | ||||
|                 }); | ||||
|                 $.each(items,function(idx,li) { | ||||
|                     that.element.append(li); | ||||
|                 }) | ||||
|             } | ||||
|         }, | ||||
|         width: function(desiredWidth) { | ||||
|             this.uiWidth = desiredWidth; | ||||
|             this._resize(); | ||||
|         }, | ||||
|         height: function(desiredHeight) { | ||||
|             this.uiHeight = desiredHeight; | ||||
|             this._resize(); | ||||
|         }, | ||||
|         addItem: function(data) { | ||||
|             var that = this; | ||||
|             data = data || {}; | ||||
|             var li = $('<li>'); | ||||
|             var added = false; | ||||
|             if (this.activeSort) { | ||||
|                 var items = this.items(); | ||||
|                 var skip = false; | ||||
|                 items.each(function(i,el) { | ||||
|                     if (added) { return } | ||||
|                     var itemData = el.data('data'); | ||||
|                     if (that.activeSort(data,itemData) < 0) { | ||||
|                          li.insertBefore(el.closest("li")); | ||||
|                          added = true; | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
|             if (!added) { | ||||
|                 li.appendTo(this.element); | ||||
|             } | ||||
|             var row = $('<div/>').addClass("red-ui-editableList-item-content").appendTo(li); | ||||
|             row.data('data',data); | ||||
|             if (this.options.sortable === true) { | ||||
|                 $('<i class="red-ui-editableList-item-handle fa fa-bars"></i>').appendTo(li); | ||||
|                 li.addClass("red-ui-editableList-item-sortable"); | ||||
|             } | ||||
|             if (this.options.removable) { | ||||
|                 var deleteButton = $('<a/>',{href:"#",class:"red-ui-editableList-item-remove editor-button editor-button-small"}).appendTo(li); | ||||
|                 $('<i/>',{class:"fa fa-remove"}).appendTo(deleteButton); | ||||
|                 li.addClass("red-ui-editableList-item-removable"); | ||||
|                 deleteButton.click(function(evt) { | ||||
|                     evt.preventDefault(); | ||||
|                     var data = row.data('data'); | ||||
|                     li.addClass("red-ui-editableList-item-deleting") | ||||
|                     li.fadeOut(300, function() { | ||||
|                         $(this).remove(); | ||||
|                         if (that.options.removeItem) { | ||||
|                             that.options.removeItem(data); | ||||
|                         } | ||||
|                     }); | ||||
|                 }); | ||||
|             } | ||||
|             if (this.options.addItem) { | ||||
|                 var index = that.element.children().length-1; | ||||
|                 setTimeout(function() { | ||||
|                     that.options.addItem(row,index,data); | ||||
|                     if (that.activeFilter) { | ||||
|                         try { | ||||
|                             if (!that.activeFilter(data)) { | ||||
|                                 li.hide(); | ||||
|                             } | ||||
|                         } catch(err) { | ||||
|                         } | ||||
|                     } | ||||
|  | ||||
|                     if (!that.activeSort && that.scrollOnAdd) { | ||||
|                         setTimeout(function() { | ||||
|                             that.uiContainer.scrollTop(that.element.height()); | ||||
|                         },0); | ||||
|                     } | ||||
|                 },0); | ||||
|             } | ||||
|         }, | ||||
|         addItems: function(items) { | ||||
|             for (var i=0; i<items.length;i++) { | ||||
|                 this.addItem(items[i]); | ||||
|             } | ||||
|         }, | ||||
|         removeItem: function(data) { | ||||
|             var items = this.element.children().filter(function(f) { | ||||
|                 return data === $(this).find(".red-ui-editableList-item-content").data('data'); | ||||
|             }); | ||||
|             items.remove(); | ||||
|             if (this.options.removeItem) { | ||||
|                 this.options.removeItem(data); | ||||
|             } | ||||
|         }, | ||||
|         items: function() { | ||||
|             return this.element.children().map(function(i) { return $(this).find(".red-ui-editableList-item-content"); }); | ||||
|         }, | ||||
|         empty: function() { | ||||
|             this.element.empty(); | ||||
|         }, | ||||
|         filter: function(filter) { | ||||
|             if (filter !== undefined) { | ||||
|                 this.activeFilter = filter; | ||||
|             } | ||||
|             return this._refreshFilter(); | ||||
|         }, | ||||
|         sort: function(sort) { | ||||
|             if (sort !== undefined) { | ||||
|                 this.activeSort = sort; | ||||
|             } | ||||
|             return this._refreshSort(); | ||||
|         }, | ||||
|         length: function() { | ||||
|             return this.element.children().length; | ||||
|         } | ||||
|     }); | ||||
| })(jQuery); | ||||
| @@ -1,5 +1,5 @@ | ||||
| /** | ||||
|  * Copyright 2014 IBM Corp. | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation
 | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
| @@ -13,9 +13,6 @@ | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| RED.menu = (function() { | ||||
| 
 | ||||
|     var menuItems = {}; | ||||
| @@ -23,21 +20,38 @@ RED.menu = (function() { | ||||
|     function createMenuItem(opt) { | ||||
|         var item; | ||||
| 
 | ||||
|         function setState() { | ||||
|             var savedStateActive = isSavedStateActive(opt.id); | ||||
|         if (opt !== null && opt.id) { | ||||
|             var themeSetting = RED.settings.theme("menu."+opt.id); | ||||
|             if (themeSetting === false) { | ||||
|                 return null; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         function setInitialState() { | ||||
|             var savedStateActive = RED.settings.get("menu-" + opt.id); | ||||
|             if (opt.setting) { | ||||
|                 // May need to migrate pre-0.17 setting
 | ||||
| 
 | ||||
|                 if (savedStateActive !== null) { | ||||
|                     RED.settings.set(opt.setting,savedStateActive); | ||||
|                     RED.settings.remove("menu-" + opt.id); | ||||
|                 } else { | ||||
|                     savedStateActive = RED.settings.get(opt.setting); | ||||
|                 } | ||||
|             } | ||||
|             if (savedStateActive) { | ||||
|                 link.addClass("active"); | ||||
|                 opt.onselect.call(opt, true); | ||||
|                 triggerAction(opt.id,true); | ||||
|             } else if (savedStateActive === false) { | ||||
|                 link.removeClass("active"); | ||||
|                 opt.onselect.call(opt, false); | ||||
|                 triggerAction(opt.id,false); | ||||
|             } else if (opt.hasOwnProperty("selected")) { | ||||
|                 if (opt.selected) { | ||||
|                     link.addClass("active"); | ||||
|                 } else { | ||||
|                     link.removeClass("active"); | ||||
|                 } | ||||
|                 opt.onselect.call(opt, opt.selected); | ||||
|                 triggerAction(opt.id,opt.selected); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
| @@ -45,12 +59,16 @@ RED.menu = (function() { | ||||
|             item = $('<li class="divider"></li>'); | ||||
|         } else { | ||||
|             item = $('<li></li>'); | ||||
|              | ||||
| 
 | ||||
|             if (opt.group) { | ||||
|                 item.addClass("menu-group-"+opt.group); | ||||
| 
 | ||||
|             } | ||||
|             var linkContent = '<a '+(opt.id?'id="'+opt.id+'" ':'')+'tabindex="-1" href="#">'; | ||||
|             if (opt.toggle) { | ||||
|                 linkContent += '<i class="fa fa-square pull-left"></i>'; | ||||
|                 linkContent += '<i class="fa fa-check-square pull-left"></i>'; | ||||
|                  | ||||
| 
 | ||||
|             } | ||||
|             if (opt.icon !== undefined) { | ||||
|                 if (/\.png/.test(opt.icon)) { | ||||
| @@ -59,22 +77,23 @@ RED.menu = (function() { | ||||
|                     linkContent += '<i class="'+(opt.icon?opt.icon:'" style="display: inline-block;"')+'"></i> '; | ||||
|                 } | ||||
|             } | ||||
|              | ||||
| 
 | ||||
|             if (opt.sublabel) { | ||||
|                 linkContent += '<span class="menu-label-container"><span class="menu-label">'+opt.label+'</span>'+ | ||||
|                                '<span class="menu-sublabel">'+opt.sublabel+'</span></span>' | ||||
|             } else { | ||||
|                 linkContent += '<span class="menu-label">'+opt.label+'</span>' | ||||
|             } | ||||
|              | ||||
| 
 | ||||
|             linkContent += '</a>'; | ||||
|                  | ||||
| 
 | ||||
|             var link = $(linkContent).appendTo(item); | ||||
| 
 | ||||
|             menuItems[opt.id] = opt; | ||||
| 
 | ||||
|             if (opt.onselect) { | ||||
|                 link.click(function() { | ||||
|                 link.click(function(e) { | ||||
|                     e.preventDefault(); | ||||
|                     if ($(this).parent().hasClass("disabled")) { | ||||
|                         return; | ||||
|                     } | ||||
| @@ -96,10 +115,12 @@ RED.menu = (function() { | ||||
|                             setSelected(opt.id, !selected); | ||||
|                         } | ||||
|                     } else { | ||||
|                         opt.onselect.call(opt); | ||||
|                         triggerAction(opt.id); | ||||
|                     } | ||||
|                 }); | ||||
|                 setState(); | ||||
|                 if (opt.toggle) { | ||||
|                     setInitialState(); | ||||
|                 } | ||||
|             } else if (opt.href) { | ||||
|                 link.attr("target","_blank").attr("href",opt.href); | ||||
|             } else if (!opt.options) { | ||||
| @@ -113,23 +134,15 @@ RED.menu = (function() { | ||||
|                 var submenu = $('<ul id="'+opt.id+'-submenu" class="dropdown-menu"></ul>').appendTo(item); | ||||
| 
 | ||||
|                 for (var i=0;i<opt.options.length;i++) { | ||||
|                     createMenuItem(opt.options[i]).appendTo(submenu); | ||||
|                     var li = createMenuItem(opt.options[i]); | ||||
|                     if (li) { | ||||
|                         li.appendTo(submenu); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if (opt.disabled) { | ||||
|                 item.addClass("disabled"); | ||||
|             } | ||||
|             if (opt.tip) { | ||||
|                 item.popover({ | ||||
|                     placement:"left", | ||||
|                     trigger: "hover", | ||||
|                     delay: { show: 350, hide: 20 }, | ||||
|                     html: true, | ||||
|                     container:'body', | ||||
|                     content: opt.tip | ||||
|                 }); | ||||
|             } | ||||
|              | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
| @@ -138,34 +151,46 @@ RED.menu = (function() { | ||||
|     } | ||||
|     function createMenu(options) { | ||||
| 
 | ||||
|         var button = $("#"+options.id); | ||||
|         var menuParent = $("#"+options.id); | ||||
| 
 | ||||
|         //button.click(function(event) {
 | ||||
|         //    $("#"+options.id+"-submenu").show();
 | ||||
|         //    event.preventDefault();
 | ||||
|         //});
 | ||||
|          | ||||
|          | ||||
|         var topMenu = $("<ul/>",{id:options.id+"-submenu", class:"dropdown-menu pull-right"}).insertAfter(button); | ||||
|         var topMenu = $("<ul/>",{id:options.id+"-submenu", class:"dropdown-menu pull-right"}); | ||||
| 
 | ||||
|         if (menuParent.length === 1) { | ||||
|             topMenu.insertAfter(menuParent); | ||||
|         } | ||||
| 
 | ||||
|         var lastAddedSeparator = false; | ||||
|         for (var i=0;i<options.options.length;i++) { | ||||
|             var opt = options.options[i]; | ||||
|             createMenuItem(opt).appendTo(topMenu); | ||||
|             if (opt !== null || !lastAddedSeparator) { | ||||
|                 var li = createMenuItem(opt); | ||||
|                 if (li) { | ||||
|                     li.appendTo(topMenu); | ||||
|                     lastAddedSeparator = (opt === null); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         return topMenu; | ||||
|     } | ||||
| 
 | ||||
|     function isSavedStateActive(id) { | ||||
|         return RED.settings.get("menu-" + id); | ||||
|     function triggerAction(id, args) { | ||||
|         var opt = menuItems[id]; | ||||
|         var callback = opt.onselect; | ||||
|         if (typeof opt.onselect === 'string') { | ||||
|             callback = RED.actions.get(opt.onselect); | ||||
|         } | ||||
|         if (callback) { | ||||
|             callback.call(opt,args); | ||||
|         } else { | ||||
|             console.log("No callback for",id,opt.onselect); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     function isSelected(id) { | ||||
|         return $("#" + id).hasClass("active"); | ||||
|     } | ||||
| 
 | ||||
|     function setSavedState(id, state) { | ||||
|         RED.settings.set("menu-" + id, state); | ||||
|     } | ||||
| 
 | ||||
|     function setSelected(id,state) { | ||||
|         if (isSelected(id) == state) { | ||||
|             return; | ||||
| @@ -176,10 +201,14 @@ RED.menu = (function() { | ||||
|         } else { | ||||
|             $("#"+id).removeClass("active"); | ||||
|         } | ||||
|         if (opt.onselect) { | ||||
|             opt.onselect.call(opt,state); | ||||
|         if (opt && opt.onselect) { | ||||
|             triggerAction(opt.id,state); | ||||
|         } | ||||
|         setSavedState(id, state); | ||||
|         RED.settings.set(opt.setting||("menu-"+opt.id), state); | ||||
|     } | ||||
| 
 | ||||
|     function toggleSelected(id) { | ||||
|         setSelected(id,!isSelected(id)); | ||||
|     } | ||||
| 
 | ||||
|     function setDisabled(id,state) { | ||||
| @@ -191,30 +220,44 @@ RED.menu = (function() { | ||||
|     } | ||||
| 
 | ||||
|     function addItem(id,opt) { | ||||
|         createMenuItem(opt).appendTo("#"+id+"-submenu"); | ||||
|         var item = createMenuItem(opt); | ||||
|         if (opt.group) { | ||||
|             var groupItems = $("#"+id+"-submenu").children(".menu-group-"+opt.group); | ||||
|             if (groupItems.length === 0) { | ||||
|                 item.appendTo("#"+id+"-submenu"); | ||||
|             } else { | ||||
|                 for (var i=0;i<groupItems.length;i++) { | ||||
|                     var groupItem = groupItems[i]; | ||||
|                     var label = $(groupItem).find(".menu-label").html(); | ||||
|                     if (opt.label < label) { | ||||
|                         $(groupItem).before(item); | ||||
|                         break; | ||||
|                     } | ||||
|                 } | ||||
|                 if (i === groupItems.length) { | ||||
|                     item.appendTo("#"+id+"-submenu"); | ||||
|                 } | ||||
|             } | ||||
|         } else { | ||||
|             item.appendTo("#"+id+"-submenu"); | ||||
|         } | ||||
|     } | ||||
|     function removeItem(id) { | ||||
|         $("#"+id).parent().remove(); | ||||
|     } | ||||
| 
 | ||||
|     function setAction(id,action) { | ||||
|         menuItems[id].onselect = action; | ||||
|         $("#"+id).click(function() { | ||||
|             if ($(this).parent().hasClass("disabled")) { | ||||
|                 return; | ||||
|             } | ||||
|             if (menuItems[id].toggle) { | ||||
|                 setSelected(id,!isSelected(id)); | ||||
|             } else { | ||||
|                 menuItems[id].onselect.call(menuItems[id]); | ||||
|             } | ||||
|         }); | ||||
|         var opt = menuItems[id]; | ||||
|         if (opt) { | ||||
|             opt.onselect = action; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     return { | ||||
|         init: createMenu, | ||||
|         setSelected: setSelected, | ||||
|         isSelected: isSelected, | ||||
|         toggleSelected: toggleSelected, | ||||
|         setDisabled: setDisabled, | ||||
|         addItem: addItem, | ||||
|         removeItem: removeItem, | ||||
							
								
								
									
										81
									
								
								editor/js/ui/common/panels.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,81 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
|  | ||||
| RED.panels = (function() { | ||||
|  | ||||
|     function createPanel(options) { | ||||
|         var container = options.container || $("#"+options.id); | ||||
|         var children = container.children(); | ||||
|         if (children.length !== 2) { | ||||
|             throw new Error("Container must have exactly two children"); | ||||
|         } | ||||
|  | ||||
|         container.addClass("red-ui-panels"); | ||||
|         var separator = $('<div class="red-ui-panels-separator"></div>').insertAfter(children[0]); | ||||
|         var startPosition; | ||||
|         var panelHeights = []; | ||||
|         var modifiedHeights = false; | ||||
|         var panelRatio; | ||||
|  | ||||
|         separator.draggable({ | ||||
|                 axis: "y", | ||||
|                 containment: container, | ||||
|                 scroll: false, | ||||
|                 start:function(event,ui) { | ||||
|                     var height = container.height(); | ||||
|                     startPosition = ui.position.top; | ||||
|                     panelHeights = [$(children[0]).height(),$(children[1]).height()]; | ||||
|                 }, | ||||
|                 drag: function(event,ui) { | ||||
|                     var height = container.height(); | ||||
|                     var delta = ui.position.top-startPosition; | ||||
|                     var newHeights = [panelHeights[0]+delta,panelHeights[1]-delta]; | ||||
|                     $(children[0]).height(newHeights[0]); | ||||
|                     $(children[1]).height(newHeights[1]); | ||||
|                     if (options.resize) { | ||||
|                         options.resize(newHeights[0],newHeights[1]); | ||||
|                     } | ||||
|                     ui.position.top -= delta; | ||||
|                     panelRatio = newHeights[0]/height; | ||||
|                 }, | ||||
|                 stop:function(event,ui) { | ||||
|                     modifiedHeights = true; | ||||
|                 } | ||||
|         }); | ||||
|  | ||||
|         return { | ||||
|             resize: function(height) { | ||||
|                 var panelHeights = [$(children[0]).height(),$(children[1]).height()]; | ||||
|                 container.height(height); | ||||
|                 if (modifiedHeights) { | ||||
|                     var topPanelHeight = panelRatio*height; | ||||
|                     var bottomPanelHeight = height - topPanelHeight - 48; | ||||
|                     panelHeights = [topPanelHeight,bottomPanelHeight]; | ||||
|                     $(children[0]).height(panelHeights[0]); | ||||
|                     $(children[1]).height(panelHeights[1]); | ||||
|                 } | ||||
|                 if (options.resize) { | ||||
|                     options.resize(panelHeights[0],panelHeights[1]); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return { | ||||
|         create: createPanel | ||||
|     } | ||||
| })(); | ||||
							
								
								
									
										149
									
								
								editor/js/ui/common/popover.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,149 @@ | ||||
| /** | ||||
|  * Copyright JS Foundation and other contributors, http://js.foundation | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  **/ | ||||
|  | ||||
| RED.popover = (function() { | ||||
|     var deltaSizes = { | ||||
|         "default": { | ||||
|             top: 10, | ||||
|             leftRight: 17, | ||||
|             leftLeft: 25 | ||||
|         }, | ||||
|         "small": { | ||||
|             top: 5, | ||||
|             leftRight: 17, | ||||
|             leftLeft: 16 | ||||
|         } | ||||
|     } | ||||
|     function createPopover(options) { | ||||
|         var target = options.target; | ||||
|         var direction = options.direction || "right"; | ||||
|         var trigger = options.trigger; | ||||
|         var content = options.content; | ||||
|         var delay = options.delay; | ||||
|         var autoClose = options.autoClose; | ||||
|         var width = options.width||"auto"; | ||||
|         var size = options.size||"default"; | ||||
|         if (!deltaSizes[size]) { | ||||
|             throw new Error("Invalid RED.popover size value:",size); | ||||
|         } | ||||
|  | ||||
|         var timer = null; | ||||
|         var active; | ||||
|         var div; | ||||
|  | ||||
|         var openPopup = function(instant) { | ||||
|             if (active) { | ||||
|                 div = $('<div class="red-ui-popover red-ui-popover-'+direction+'"></div>').appendTo("body"); | ||||
|                 if (size !== "default") { | ||||
|                     div.addClass("red-ui-popover-size-"+size); | ||||
|                 } | ||||
|                 if (typeof content === 'function') { | ||||
|                     content.call(res).appendTo(div); | ||||
|                 } else { | ||||
|                     div.html(content); | ||||
|                 } | ||||
|                 if (width !== "auto") { | ||||
|                     div.width(width); | ||||
|                 } | ||||
|  | ||||
|  | ||||
|                 var targetPos = target.offset(); | ||||
|                 var targetWidth = target.width(); | ||||
|                 var targetHeight = target.height(); | ||||
|                 var divHeight = div.height(); | ||||
|                 var divWidth = div.width(); | ||||
|                 if (direction === 'right') { | ||||
|                     div.css({top: targetPos.top+targetHeight/2-divHeight/2-deltaSizes[size].top,left:targetPos.left+targetWidth+deltaSizes[size].leftRight}); | ||||
|                 } else if (direction === 'left') { | ||||
|                     div.css({top: targetPos.top+targetHeight/2-divHeight/2-deltaSizes[size].top,left:targetPos.left-deltaSizes[size].leftLeft-divWidth}); | ||||
|                 } | ||||
|                 if (instant) { | ||||
|                     div.show(); | ||||
|                 } else { | ||||
|                     div.fadeIn("fast"); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         var closePopup = function(instant) { | ||||
|             if (!active) { | ||||
|                 if (div) { | ||||
|                     if (instant) { | ||||
|                         $(this).remove(); | ||||
|                     } else { | ||||
|                         div.fadeOut("fast",function() { | ||||
|                             $(this).remove(); | ||||
|                         }); | ||||
|                     } | ||||
|                     div = null; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (trigger === 'hover') { | ||||
|             target.on('mouseenter',function(e) { | ||||
|                 clearTimeout(timer); | ||||
|                 active = true; | ||||
|                 timer = setTimeout(openPopup,delay.show); | ||||
|             }); | ||||
|             target.on('mouseleave', function(e) { | ||||
|                 if (timer) { | ||||
|                     clearTimeout(timer); | ||||
|                 } | ||||
|                 active = false; | ||||
|                 setTimeout(closePopup,delay.hide); | ||||
|             }); | ||||
|         } else if (trigger === 'click') { | ||||
|             target.click(function(e) { | ||||
|                 e.preventDefault(); | ||||
|                 e.stopPropagation(); | ||||
|                 active = !active; | ||||
|                 if (!active) { | ||||
|                     closePopup(); | ||||
|                 } else { | ||||
|                     openPopup(); | ||||
|                 } | ||||
|             }); | ||||
|         } else if (autoClose) { | ||||
|             setTimeout(function() { | ||||
|                 active = false; | ||||
|                 closePopup(); | ||||
|             },autoClose); | ||||
|         } | ||||
|         var res = { | ||||
|             setContent: function(_content) { | ||||
|                 content = _content; | ||||
|                 return res; | ||||
|             }, | ||||
|             open: function (instant) { | ||||
|                 active = true; | ||||
|                 openPopup(instant); | ||||
|                 return res; | ||||
|             }, | ||||
|             close: function (instant) { | ||||
|                 active = false; | ||||
|                 closePopup(instant); | ||||
|                 return res; | ||||
|             } | ||||
|         } | ||||
|         return res; | ||||
|  | ||||
|     } | ||||
|  | ||||
|     return { | ||||
|         create: createPopover | ||||
|     } | ||||
|  | ||||
| })(); | ||||