rebuild_on_change.ts 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. ///<reference path="../../headers/common.d.ts" />
  2. import angular from 'angular';
  3. import _ from 'lodash';
  4. import $ from 'jquery';
  5. import coreModule from '../core_module';
  6. function getBlockNodes(nodes) {
  7. var node = nodes[0];
  8. var endNode = nodes[nodes.length - 1];
  9. var blockNodes;
  10. for (var i = 1; node !== endNode && (node = node.nextSibling); i++) {
  11. if (blockNodes || nodes[i] !== node) {
  12. if (!blockNodes) {
  13. blockNodes = $([].slice.call(nodes, 0, i));
  14. }
  15. blockNodes.push(node);
  16. }
  17. }
  18. return blockNodes || nodes;
  19. }
  20. function rebuildOnChange($animate) {
  21. return {
  22. multiElement: true,
  23. terminal: true,
  24. transclude: true,
  25. priority: 600,
  26. restrict: 'E',
  27. link: function(scope, elem, attrs, ctrl, transclude) {
  28. var block, childScope, previousElements;
  29. function cleanUp() {
  30. if (previousElements) {
  31. previousElements.remove();
  32. previousElements = null;
  33. }
  34. if (childScope) {
  35. childScope.$destroy();
  36. childScope = null;
  37. }
  38. if (block) {
  39. previousElements = getBlockNodes(block.clone);
  40. $animate.leave(previousElements).then(function() {
  41. previousElements = null;
  42. });
  43. block = null;
  44. }
  45. }
  46. scope.$watch(attrs.property, function rebuildOnChangeAction(value, oldValue) {
  47. if (childScope && value !== oldValue) {
  48. cleanUp();
  49. }
  50. if (!childScope && (value || attrs.showNull)) {
  51. transclude(function(clone, newScope) {
  52. childScope = newScope;
  53. clone[clone.length++] = document.createComment(' end rebuild on change ');
  54. block = {clone: clone};
  55. $animate.enter(clone, elem.parent(), elem);
  56. });
  57. } else {
  58. cleanUp();
  59. }
  60. });
  61. }
  62. };
  63. }
  64. coreModule.directive('rebuildOnChange', rebuildOnChange);