ngx-owl-carousel-o
Version:
Angular powered owl-carousel
263 lines • 26 kB
JavaScript
import * as tslib_1 from "tslib";
import { LocationStrategy } from '@angular/common';
import { Attribute, Directive, ElementRef, HostBinding, HostListener, Input, Renderer2, isDevMode } from '@angular/core';
import { NavigationEnd, Router, ActivatedRoute } from '@angular/router';
var OwlRouterLinkDirective = /** @class */ (function () {
function OwlRouterLinkDirective(router, route, tabIndex, renderer, el) {
this.router = router;
this.route = route;
this.stopLink = false;
this.commands = [];
if (tabIndex == null) {
renderer.setAttribute(el.nativeElement, 'tabindex', '0');
}
}
Object.defineProperty(OwlRouterLinkDirective.prototype, "owlRouterLink", {
set: function (commands) {
if (commands != null) {
this.commands = Array.isArray(commands) ? commands : [commands];
}
else {
this.commands = [];
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(OwlRouterLinkDirective.prototype, "preserveQueryParams", {
/**
* @deprecated 4.0.0 use `queryParamsHandling` instead.
*/
set: function (value) {
if (isDevMode() && console && console.warn) {
console.warn('preserveQueryParams is deprecated!, use queryParamsHandling instead.');
}
this.preserve = value;
},
enumerable: true,
configurable: true
});
OwlRouterLinkDirective.prototype.onClick = function () {
var extras = {
skipLocationChange: attrBoolValue(this.skipLocationChange),
replaceUrl: attrBoolValue(this.replaceUrl),
};
if (this.stopLink) {
return false;
}
this.router.navigateByUrl(this.urlTree, extras);
return true;
};
Object.defineProperty(OwlRouterLinkDirective.prototype, "urlTree", {
get: function () {
return this.router.createUrlTree(this.commands, {
relativeTo: this.route,
queryParams: this.queryParams,
fragment: this.fragment,
preserveQueryParams: attrBoolValue(this.preserve),
queryParamsHandling: this.queryParamsHandling,
preserveFragment: attrBoolValue(this.preserveFragment),
});
},
enumerable: true,
configurable: true
});
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object)
], OwlRouterLinkDirective.prototype, "queryParams", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", String)
], OwlRouterLinkDirective.prototype, "fragment", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", String)
], OwlRouterLinkDirective.prototype, "queryParamsHandling", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], OwlRouterLinkDirective.prototype, "preserveFragment", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], OwlRouterLinkDirective.prototype, "skipLocationChange", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], OwlRouterLinkDirective.prototype, "replaceUrl", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object)
], OwlRouterLinkDirective.prototype, "stopLink", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], OwlRouterLinkDirective.prototype, "owlRouterLink", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean),
tslib_1.__metadata("design:paramtypes", [Boolean])
], OwlRouterLinkDirective.prototype, "preserveQueryParams", null);
tslib_1.__decorate([
HostListener('click'),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", []),
tslib_1.__metadata("design:returntype", Boolean)
], OwlRouterLinkDirective.prototype, "onClick", null);
OwlRouterLinkDirective = tslib_1.__decorate([
Directive({ selector: ':not(a)[owlRouterLink]' }),
tslib_1.__param(2, Attribute('tabindex')),
tslib_1.__metadata("design:paramtypes", [Router, ActivatedRoute, String, Renderer2, ElementRef])
], OwlRouterLinkDirective);
return OwlRouterLinkDirective;
}());
export { OwlRouterLinkDirective };
/**
* @description
*
* Lets you link to specific routes in your app.
*
* See `RouterLink` for more information.
*
* @ngModule RouterModule
*
* @publicApi
*/
var OwlRouterLinkWithHrefDirective = /** @class */ (function () {
function OwlRouterLinkWithHrefDirective(router, route, locationStrategy) {
var _this = this;
this.router = router;
this.route = route;
this.locationStrategy = locationStrategy;
this.stopLink = false;
this.commands = [];
this.subscription = router.events.subscribe(function (s) {
if (s instanceof NavigationEnd) {
_this.updateTargetUrlAndHref();
}
});
}
Object.defineProperty(OwlRouterLinkWithHrefDirective.prototype, "owlRouterLink", {
set: function (commands) {
if (commands != null) {
this.commands = Array.isArray(commands) ? commands : [commands];
}
else {
this.commands = [];
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(OwlRouterLinkWithHrefDirective.prototype, "preserveQueryParams", {
set: function (value) {
if (isDevMode() && console && console.warn) {
console.warn('preserveQueryParams is deprecated, use queryParamsHandling instead.');
}
this.preserve = value;
},
enumerable: true,
configurable: true
});
OwlRouterLinkWithHrefDirective.prototype.ngOnChanges = function (changes) { this.updateTargetUrlAndHref(); };
OwlRouterLinkWithHrefDirective.prototype.ngOnDestroy = function () { this.subscription.unsubscribe(); };
OwlRouterLinkWithHrefDirective.prototype.onClick = function (button, ctrlKey, metaKey, shiftKey) {
if (button !== 0 || ctrlKey || metaKey || shiftKey) {
return true;
}
if (typeof this.target === 'string' && this.target !== '_self') {
return true;
}
if (this.stopLink) {
return false;
}
var extras = {
skipLocationChange: attrBoolValue(this.skipLocationChange),
replaceUrl: attrBoolValue(this.replaceUrl),
};
this.router.navigateByUrl(this.urlTree, extras);
return false;
};
OwlRouterLinkWithHrefDirective.prototype.updateTargetUrlAndHref = function () {
this.href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.urlTree));
};
Object.defineProperty(OwlRouterLinkWithHrefDirective.prototype, "urlTree", {
get: function () {
return this.router.createUrlTree(this.commands, {
relativeTo: this.route,
queryParams: this.queryParams,
fragment: this.fragment,
preserveQueryParams: attrBoolValue(this.preserve),
queryParamsHandling: this.queryParamsHandling,
preserveFragment: attrBoolValue(this.preserveFragment),
});
},
enumerable: true,
configurable: true
});
tslib_1.__decorate([
HostBinding('attr.target'), Input(),
tslib_1.__metadata("design:type", String)
], OwlRouterLinkWithHrefDirective.prototype, "target", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object)
], OwlRouterLinkWithHrefDirective.prototype, "queryParams", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", String)
], OwlRouterLinkWithHrefDirective.prototype, "fragment", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", String)
], OwlRouterLinkWithHrefDirective.prototype, "queryParamsHandling", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], OwlRouterLinkWithHrefDirective.prototype, "preserveFragment", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], OwlRouterLinkWithHrefDirective.prototype, "skipLocationChange", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], OwlRouterLinkWithHrefDirective.prototype, "replaceUrl", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object)
], OwlRouterLinkWithHrefDirective.prototype, "stopLink", void 0);
tslib_1.__decorate([
HostBinding(),
tslib_1.__metadata("design:type", String)
], OwlRouterLinkWithHrefDirective.prototype, "href", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], OwlRouterLinkWithHrefDirective.prototype, "owlRouterLink", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean),
tslib_1.__metadata("design:paramtypes", [Boolean])
], OwlRouterLinkWithHrefDirective.prototype, "preserveQueryParams", null);
tslib_1.__decorate([
HostListener('click', ['$event.button', '$event.ctrlKey', '$event.metaKey', '$event.shiftKey']),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", [Number, Boolean, Boolean, Boolean]),
tslib_1.__metadata("design:returntype", Boolean)
], OwlRouterLinkWithHrefDirective.prototype, "onClick", null);
OwlRouterLinkWithHrefDirective = tslib_1.__decorate([
Directive({ selector: 'a[owlRouterLink]' }),
tslib_1.__metadata("design:paramtypes", [Router, ActivatedRoute,
LocationStrategy])
], OwlRouterLinkWithHrefDirective);
return OwlRouterLinkWithHrefDirective;
}());
export { OwlRouterLinkWithHrefDirective };
function attrBoolValue(s) {
return s === '' || !!s;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"owl-router-link.directive.js","sourceRoot":"ng://ngx-owl-carousel-o/","sources":["lib/carousel/owl-router-link.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {LocationStrategy} from '@angular/common';\r\nimport {Attribute, Directive, ElementRef, HostBinding, HostListener, Input, OnChanges, OnDestroy, Renderer2, isDevMode} from '@angular/core';\r\nimport {Subscription} from 'rxjs';\r\n\r\nimport {NavigationEnd, RouterEvent, Router, ActivatedRoute, UrlTree} from '@angular/router';\r\n\r\nexport type QueryParamsHandling = 'merge' | 'preserve' | '';\r\n\r\n@Directive({selector: ':not(a)[owlRouterLink]'})\r\nexport class OwlRouterLinkDirective {\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() queryParams !: {[k: string]: any};\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() fragment !: string;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() queryParamsHandling !: QueryParamsHandling;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() preserveFragment !: boolean;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() skipLocationChange !: boolean;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() replaceUrl !: boolean;\r\n\r\n  @Input() stopLink = false;\r\n  private commands: any[] = [];\r\n  // TODO(issue/24571): remove '!'.\r\n  private preserve !: boolean;\r\n\r\n  constructor(\r\n      private router: Router, private route: ActivatedRoute,\r\n      @Attribute('tabindex') tabIndex: string, renderer: Renderer2, el: ElementRef) {\r\n    if (tabIndex == null) {\r\n      renderer.setAttribute(el.nativeElement, 'tabindex', '0');\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  set owlRouterLink(commands: any[]|string) {\r\n    if (commands != null) {\r\n      this.commands = Array.isArray(commands) ? commands : [commands];\r\n    } else {\r\n      this.commands = [];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @deprecated 4.0.0 use `queryParamsHandling` instead.\r\n   */\r\n  @Input()\r\n  set preserveQueryParams(value: boolean) {\r\n    if (isDevMode() && <any>console && <any>console.warn) {\r\n      console.warn('preserveQueryParams is deprecated!, use queryParamsHandling instead.');\r\n    }\r\n    this.preserve = value;\r\n  }\r\n\r\n  @HostListener('click')\r\n  onClick(): boolean {\r\n    const extras = {\r\n      skipLocationChange: attrBoolValue(this.skipLocationChange),\r\n      replaceUrl: attrBoolValue(this.replaceUrl),\r\n    };\r\n    if (this.stopLink) {\r\n      return false;\r\n    }\r\n    this.router.navigateByUrl(this.urlTree, extras);\r\n    return true;\r\n  }\r\n\r\n  get urlTree(): UrlTree {\r\n    return this.router.createUrlTree(this.commands, {\r\n      relativeTo: this.route,\r\n      queryParams: this.queryParams,\r\n      fragment: this.fragment,\r\n      preserveQueryParams: attrBoolValue(this.preserve),\r\n      queryParamsHandling: this.queryParamsHandling,\r\n      preserveFragment: attrBoolValue(this.preserveFragment),\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * @description\r\n *\r\n * Lets you link to specific routes in your app.\r\n *\r\n * See `RouterLink` for more information.\r\n *\r\n * @ngModule RouterModule\r\n *\r\n * @publicApi\r\n */\r\n@Directive({selector: 'a[owlRouterLink]'})\r\nexport class OwlRouterLinkWithHrefDirective implements OnChanges, OnDestroy {\r\n  // TODO(issue/24571): remove '!'.\r\n  @HostBinding('attr.target') @Input() target !: string;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() queryParams !: {[k: string]: any};\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() fragment !: string;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() queryParamsHandling !: QueryParamsHandling;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() preserveFragment !: boolean;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() skipLocationChange !: boolean;\r\n  // TODO(issue/24571): remove '!'.\r\n  @Input() replaceUrl !: boolean;\r\n  @Input() stopLink = false;\r\n\r\n  private commands: any[] = [];\r\n  private subscription: Subscription;\r\n  // TODO(issue/24571): remove '!'.\r\n  private preserve !: boolean;\r\n\r\n  // the url displayed on the anchor element.\r\n  // TODO(issue/24571): remove '!'.\r\n  @HostBinding() href !: string;\r\n\r\n  constructor(\r\n      private router: Router, private route: ActivatedRoute,\r\n      private locationStrategy: LocationStrategy) {\r\n    this.subscription = router.events.subscribe((s: RouterEvent) => {\r\n      if (s instanceof NavigationEnd) {\r\n        this.updateTargetUrlAndHref();\r\n      }\r\n    });\r\n  }\r\n\r\n  @Input()\r\n  set owlRouterLink(commands: any[]|string) {\r\n    if (commands != null) {\r\n      this.commands = Array.isArray(commands) ? commands : [commands];\r\n    } else {\r\n      this.commands = [];\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  set preserveQueryParams(value: boolean) {\r\n    if (isDevMode() && <any>console && <any>console.warn) {\r\n      console.warn('preserveQueryParams is deprecated, use queryParamsHandling instead.');\r\n    }\r\n    this.preserve = value;\r\n  }\r\n\r\n  ngOnChanges(changes: {}): any { this.updateTargetUrlAndHref(); }\r\n  ngOnDestroy(): any { this.subscription.unsubscribe(); }\r\n\r\n  @HostListener('click', ['$event.button', '$event.ctrlKey', '$event.metaKey', '$event.shiftKey'])\r\n  onClick(button: number, ctrlKey: boolean, metaKey: boolean, shiftKey: boolean): boolean {\r\n    if (button !== 0 || ctrlKey || metaKey || shiftKey) {\r\n      return true;\r\n    }\r\n\r\n    if (typeof this.target === 'string' && this.target !== '_self') {\r\n      return true;\r\n    }\r\n\r\n    if (this.stopLink) {\r\n      return false;\r\n    }\r\n\r\n    const extras = {\r\n      skipLocationChange: attrBoolValue(this.skipLocationChange),\r\n      replaceUrl: attrBoolValue(this.replaceUrl),\r\n    };\r\n    this.router.navigateByUrl(this.urlTree, extras);\r\n    return false;\r\n  }\r\n\r\n  private updateTargetUrlAndHref(): void {\r\n    this.href = this.locationStrategy.prepareExternalUrl(this.router.serializeUrl(this.urlTree));\r\n  }\r\n\r\n  get urlTree(): UrlTree {\r\n    return this.router.createUrlTree(this.commands, {\r\n      relativeTo: this.route,\r\n      queryParams: this.queryParams,\r\n      fragment: this.fragment,\r\n      preserveQueryParams: attrBoolValue(this.preserve),\r\n      queryParamsHandling: this.queryParamsHandling,\r\n      preserveFragment: attrBoolValue(this.preserveFragment),\r\n    });\r\n  }\r\n}\r\n\r\nfunction attrBoolValue(s: any): boolean {\r\n  return s === '' || !!s;\r\n}\r\n"]}