collapse.directive.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { AnimationBuilder } from '@angular/animations';
  6. import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2 } from '@angular/core';
  7. import { collapseAnimation, expandAnimation } from './collapse-animations';
  8. export class CollapseDirective {
  9. /**
  10. * @param {?} _el
  11. * @param {?} _renderer
  12. * @param {?} _builder
  13. */
  14. constructor(_el, _renderer, _builder) {
  15. this._el = _el;
  16. this._renderer = _renderer;
  17. /**
  18. * This event fires as soon as content collapses
  19. */
  20. this.collapsed = new EventEmitter();
  21. /**
  22. * This event fires when collapsing is started
  23. */
  24. this.collapses = new EventEmitter();
  25. /**
  26. * This event fires as soon as content becomes visible
  27. */
  28. this.expanded = new EventEmitter();
  29. /**
  30. * This event fires when expansion is started
  31. */
  32. this.expands = new EventEmitter();
  33. // shown
  34. this.isExpanded = true;
  35. // hidden
  36. this.isCollapsed = false;
  37. // stale state
  38. this.isCollapse = true;
  39. // animation state
  40. this.isCollapsing = false;
  41. /**
  42. * turn on/off animation
  43. */
  44. this.isAnimated = false;
  45. this._display = 'block';
  46. this._stylesLoaded = false;
  47. this._COLLAPSE_ACTION_NAME = 'collapse';
  48. this._EXPAND_ACTION_NAME = 'expand';
  49. this._factoryCollapseAnimation = _builder.build(collapseAnimation);
  50. this._factoryExpandAnimation = _builder.build(expandAnimation);
  51. }
  52. /**
  53. * @param {?} value
  54. * @return {?}
  55. */
  56. set display(value) {
  57. if (!this.isAnimated) {
  58. this._renderer.setStyle(this._el.nativeElement, 'display', value);
  59. return;
  60. }
  61. this._display = value;
  62. if (value === 'none') {
  63. this.hide();
  64. return;
  65. }
  66. this.show();
  67. }
  68. /**
  69. * A flag indicating visibility of content (shown or hidden)
  70. * @param {?} value
  71. * @return {?}
  72. */
  73. set collapse(value) {
  74. if (!this._player || this._isAnimationDone) {
  75. this.isExpanded = value;
  76. this.toggle();
  77. }
  78. }
  79. /**
  80. * @return {?}
  81. */
  82. get collapse() {
  83. return this.isExpanded;
  84. }
  85. /**
  86. * @return {?}
  87. */
  88. ngAfterViewChecked() {
  89. this._stylesLoaded = true;
  90. if (!this._player || !this._isAnimationDone) {
  91. return;
  92. }
  93. this._player.reset();
  94. this._renderer.setStyle(this._el.nativeElement, 'height', '*');
  95. }
  96. /**
  97. * allows to manually toggle content visibility
  98. * @return {?}
  99. */
  100. toggle() {
  101. if (this.isExpanded) {
  102. this.hide();
  103. }
  104. else {
  105. this.show();
  106. }
  107. }
  108. /**
  109. * allows to manually hide content
  110. * @return {?}
  111. */
  112. hide() {
  113. this.isCollapsing = true;
  114. this.isExpanded = false;
  115. this.isCollapsed = true;
  116. this.isCollapsing = false;
  117. this.collapses.emit(this);
  118. this._isAnimationDone = false;
  119. this.animationRun(this.isAnimated, this._COLLAPSE_ACTION_NAME)((/**
  120. * @return {?}
  121. */
  122. () => {
  123. this._isAnimationDone = true;
  124. this.collapsed.emit(this);
  125. this._renderer.setStyle(this._el.nativeElement, 'display', 'none');
  126. }));
  127. }
  128. /**
  129. * allows to manually show collapsed content
  130. * @return {?}
  131. */
  132. show() {
  133. this._renderer.setStyle(this._el.nativeElement, 'display', this._display);
  134. this.isCollapsing = true;
  135. this.isExpanded = true;
  136. this.isCollapsed = false;
  137. this.isCollapsing = false;
  138. this.expands.emit(this);
  139. this._isAnimationDone = false;
  140. this.animationRun(this.isAnimated, this._EXPAND_ACTION_NAME)((/**
  141. * @return {?}
  142. */
  143. () => {
  144. this._isAnimationDone = true;
  145. this.expanded.emit(this);
  146. }));
  147. }
  148. /**
  149. * @param {?} isAnimated
  150. * @param {?} action
  151. * @return {?}
  152. */
  153. animationRun(isAnimated, action) {
  154. if (!isAnimated || !this._stylesLoaded) {
  155. return (/**
  156. * @param {?} callback
  157. * @return {?}
  158. */
  159. (callback) => callback());
  160. }
  161. this._renderer.setStyle(this._el.nativeElement, 'overflow', 'hidden');
  162. this._renderer.addClass(this._el.nativeElement, 'collapse');
  163. /** @type {?} */
  164. const factoryAnimation = (action === this._EXPAND_ACTION_NAME)
  165. ? this._factoryExpandAnimation
  166. : this._factoryCollapseAnimation;
  167. if (this._player) {
  168. this._player.destroy();
  169. }
  170. this._player = factoryAnimation.create(this._el.nativeElement);
  171. this._player.play();
  172. return (/**
  173. * @param {?} callback
  174. * @return {?}
  175. */
  176. (callback) => this._player.onDone(callback));
  177. }
  178. }
  179. CollapseDirective.decorators = [
  180. { type: Directive, args: [{
  181. selector: '[collapse]',
  182. exportAs: 'bs-collapse',
  183. host: {
  184. '[class.collapse]': 'true'
  185. }
  186. },] }
  187. ];
  188. /** @nocollapse */
  189. CollapseDirective.ctorParameters = () => [
  190. { type: ElementRef },
  191. { type: Renderer2 },
  192. { type: AnimationBuilder }
  193. ];
  194. CollapseDirective.propDecorators = {
  195. collapsed: [{ type: Output }],
  196. collapses: [{ type: Output }],
  197. expanded: [{ type: Output }],
  198. expands: [{ type: Output }],
  199. isExpanded: [{ type: HostBinding, args: ['class.in',] }, { type: HostBinding, args: ['class.show',] }, { type: HostBinding, args: ['attr.aria-expanded',] }],
  200. isCollapsed: [{ type: HostBinding, args: ['attr.aria-hidden',] }],
  201. isCollapse: [{ type: HostBinding, args: ['class.collapse',] }],
  202. isCollapsing: [{ type: HostBinding, args: ['class.collapsing',] }],
  203. display: [{ type: Input }],
  204. isAnimated: [{ type: Input }],
  205. collapse: [{ type: Input }]
  206. };
  207. if (false) {
  208. /**
  209. * This event fires as soon as content collapses
  210. * @type {?}
  211. */
  212. CollapseDirective.prototype.collapsed;
  213. /**
  214. * This event fires when collapsing is started
  215. * @type {?}
  216. */
  217. CollapseDirective.prototype.collapses;
  218. /**
  219. * This event fires as soon as content becomes visible
  220. * @type {?}
  221. */
  222. CollapseDirective.prototype.expanded;
  223. /**
  224. * This event fires when expansion is started
  225. * @type {?}
  226. */
  227. CollapseDirective.prototype.expands;
  228. /** @type {?} */
  229. CollapseDirective.prototype.isExpanded;
  230. /** @type {?} */
  231. CollapseDirective.prototype.isCollapsed;
  232. /** @type {?} */
  233. CollapseDirective.prototype.isCollapse;
  234. /** @type {?} */
  235. CollapseDirective.prototype.isCollapsing;
  236. /**
  237. * turn on/off animation
  238. * @type {?}
  239. */
  240. CollapseDirective.prototype.isAnimated;
  241. /**
  242. * @type {?}
  243. * @private
  244. */
  245. CollapseDirective.prototype._display;
  246. /**
  247. * @type {?}
  248. * @private
  249. */
  250. CollapseDirective.prototype._factoryCollapseAnimation;
  251. /**
  252. * @type {?}
  253. * @private
  254. */
  255. CollapseDirective.prototype._factoryExpandAnimation;
  256. /**
  257. * @type {?}
  258. * @private
  259. */
  260. CollapseDirective.prototype._isAnimationDone;
  261. /**
  262. * @type {?}
  263. * @private
  264. */
  265. CollapseDirective.prototype._player;
  266. /**
  267. * @type {?}
  268. * @private
  269. */
  270. CollapseDirective.prototype._stylesLoaded;
  271. /**
  272. * @type {?}
  273. * @private
  274. */
  275. CollapseDirective.prototype._COLLAPSE_ACTION_NAME;
  276. /**
  277. * @type {?}
  278. * @private
  279. */
  280. CollapseDirective.prototype._EXPAND_ACTION_NAME;
  281. /**
  282. * @type {?}
  283. * @private
  284. */
  285. CollapseDirective.prototype._el;
  286. /**
  287. * @type {?}
  288. * @private
  289. */
  290. CollapseDirective.prototype._renderer;
  291. }
  292. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse.directive.js","sourceRoot":"ng://ngx-bootstrap/collapse/","sources":["collapse.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AnimationBuilder,\n  AnimationFactory,\n  AnimationPlayer\n} from '@angular/animations';\n\nimport {\n  AfterViewChecked,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  Renderer2\n} from '@angular/core';\n\nimport {\n  collapseAnimation,\n  expandAnimation\n} from './collapse-animations';\n\n@Directive({\n  selector: '[collapse]',\n  exportAs: 'bs-collapse',\n  host: {\n    '[class.collapse]': 'true'\n  }\n})\nexport class CollapseDirective implements AfterViewChecked {\n  /** This event fires as soon as content collapses */\n  @Output() collapsed: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires when collapsing is started */\n  @Output() collapses: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires as soon as content becomes visible */\n  @Output() expanded: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires when expansion is started */\n  @Output() expands: EventEmitter<CollapseDirective> = new EventEmitter();\n\n  // shown\n  @HostBinding('class.in')\n  @HostBinding('class.show')\n  @HostBinding('attr.aria-expanded')\n  isExpanded = true;\n  // hidden\n  @HostBinding('attr.aria-hidden') isCollapsed = false;\n  // stale state\n  @HostBinding('class.collapse') isCollapse = true;\n  // animation state\n  @HostBinding('class.collapsing') isCollapsing = false;\n\n  @Input()\n  set display(value: string) {\n    if (!this.isAnimated) {\n      this._renderer.setStyle(this._el.nativeElement, 'display', value);\n\n      return;\n    }\n\n    this._display = value;\n\n    if (value === 'none') {\n      this.hide();\n\n      return;\n    }\n\n    this.show();\n  }\n  /** turn on/off animation */\n  @Input() isAnimated = false;\n  /** A flag indicating visibility of content (shown or hidden) */\n  @Input()\n  set collapse(value: boolean) {\n    if (!this._player || this._isAnimationDone) {\n      this.isExpanded = value;\n      this.toggle();\n    }\n  }\n\n  get collapse(): boolean {\n    return this.isExpanded;\n  }\n\n  private _display = 'block';\n  private _factoryCollapseAnimation: AnimationFactory;\n  private _factoryExpandAnimation: AnimationFactory;\n  private _isAnimationDone: boolean;\n  private _player: AnimationPlayer;\n  private _stylesLoaded = false;\n\n  private _COLLAPSE_ACTION_NAME = 'collapse';\n  private _EXPAND_ACTION_NAME = 'expand';\n\n  constructor(\n    private _el: ElementRef,\n    private _renderer: Renderer2,\n    _builder: AnimationBuilder\n  ) {\n    this._factoryCollapseAnimation = _builder.build(collapseAnimation);\n    this._factoryExpandAnimation = _builder.build(expandAnimation);\n  }\n\n  ngAfterViewChecked(): void {\n    this._stylesLoaded = true;\n\n    if (!this._player || !this._isAnimationDone) {\n      return;\n    }\n\n    this._player.reset();\n    this._renderer.setStyle(this._el.nativeElement, 'height', '*');\n  }\n\n  /** allows to manually toggle content visibility */\n  toggle(): void {\n    if (this.isExpanded) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /** allows to manually hide content */\n  hide(): void {\n    this.isCollapsing = true;\n    this.isExpanded = false;\n    this.isCollapsed = true;\n    this.isCollapsing = false;\n\n    this.collapses.emit(this);\n\n    this._isAnimationDone = false;\n\n    this.animationRun(this.isAnimated, this._COLLAPSE_ACTION_NAME)(() => {\n      this._isAnimationDone = true;\n      this.collapsed.emit(this);\n      this._renderer.setStyle(this._el.nativeElement, 'display', 'none');\n    });\n  }\n  /** allows to manually show collapsed content */\n  show(): void {\n    this._renderer.setStyle(this._el.nativeElement, 'display', this._display);\n\n    this.isCollapsing = true;\n    this.isExpanded = true;\n    this.isCollapsed = false;\n    this.isCollapsing = false;\n\n    this.expands.emit(this);\n\n    this._isAnimationDone = false;\n\n    this.animationRun(this.isAnimated, this._EXPAND_ACTION_NAME)(() => {\n      this._isAnimationDone = true;\n      this.expanded.emit(this);\n    });\n  }\n\n  animationRun(isAnimated: boolean, action: string) {\n    if (!isAnimated || !this._stylesLoaded) {\n      return (callback: () => void) => callback();\n    }\n\n    this._renderer.setStyle(this._el.nativeElement, 'overflow', 'hidden');\n    this._renderer.addClass(this._el.nativeElement, 'collapse');\n\n    const factoryAnimation = (action === this._EXPAND_ACTION_NAME)\n      ? this._factoryExpandAnimation\n      : this._factoryCollapseAnimation;\n\n    if (this._player) {\n      this._player.destroy();\n    }\n\n    this._player = factoryAnimation.create(this._el.nativeElement);\n    this._player.play();\n\n    return (callback: () => void) => this._player.onDone(callback);\n  }\n}\n"]}