@junte/ui
Version:
Quality Angular UI components kit
204 lines • 18.8 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { animate, state, style, transition, trigger } from '@angular/animations';
import { Component, ContentChild, HostBinding, Input, TemplateRef } from '@angular/core';
import { BreakpointService } from '../responsive/breakpoint.service';
import { ContentApi, MethodApi, PropertyApi } from '../../core/decorators/api';
import { Feature } from '../../core/enums/feature';
import { Gutter } from '../../core/enums/gutter';
import { State } from '../../core/enums/state';
import { UI } from '../../core/enums/ui';
import { Width } from '../../core/enums/width';
var BlockComponent = /** @class */ (function () {
function BlockComponent(breakpoint) {
this.breakpoint = breakpoint;
this.ui = UI;
this._state = { success: false };
this.host = 'jnt-block-host';
this._padding = Gutter.normal;
this._spacing = Gutter.normal;
this.width = Width.default;
this.features = [];
}
Object.defineProperty(BlockComponent.prototype, "hasHelp", {
get: function () {
return !!this.blockHelpTemplate;
},
enumerable: true,
configurable: true
});
Object.defineProperty(BlockComponent.prototype, "hasHeader", {
get: function () {
return !!this.blockHeaderTemplate || !!this.title;
},
enumerable: true,
configurable: true
});
Object.defineProperty(BlockComponent.prototype, "padding", {
set: function (padding) {
this._padding = padding || Gutter.normal;
},
enumerable: true,
configurable: true
});
Object.defineProperty(BlockComponent.prototype, "spacing", {
get: function () {
return this._spacing;
},
set: function (spacing) {
this._spacing = spacing || Gutter.normal;
},
enumerable: true,
configurable: true
});
BlockComponent.prototype.success = function () {
var _this = this;
this._state.success = true;
setTimeout(function () { return _this._state.success = false; }, 2100);
};
BlockComponent.ctorParameters = function () { return [
{ type: BreakpointService }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], BlockComponent.prototype, "host", void 0);
__decorate([
HostBinding('attr.data-has-help'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], BlockComponent.prototype, "hasHelp", null);
__decorate([
HostBinding('attr.data-has-header'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], BlockComponent.prototype, "hasHeader", null);
__decorate([
HostBinding('attr.data-padding'),
__metadata("design:type", Object)
], BlockComponent.prototype, "_padding", void 0);
__decorate([
PropertyApi({
description: 'Title of block',
type: 'string'
}),
Input(),
__metadata("design:type", String)
], BlockComponent.prototype, "title", void 0);
__decorate([
PropertyApi({
description: 'Padding for block',
path: 'ui.gutter',
options: [Gutter.tiny,
Gutter.small,
Gutter.normal,
Gutter.large,
Gutter.big,
Gutter.huge],
default: Gutter.normal
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], BlockComponent.prototype, "padding", null);
__decorate([
PropertyApi({
description: 'Spacing between header, body and footer',
path: 'ui.gutter',
options: [Gutter.tiny,
Gutter.small,
Gutter.normal,
Gutter.large,
Gutter.big,
Gutter.huge],
default: Gutter.normal
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], BlockComponent.prototype, "spacing", null);
__decorate([
PropertyApi({
description: 'Block width',
path: 'ui.width',
default: Width.default,
options: [Width.default,
Width.fluid]
}),
HostBinding('attr.data-width'),
Input(),
__metadata("design:type", String)
], BlockComponent.prototype, "width", void 0);
__decorate([
PropertyApi({
description: 'State of block',
path: 'ui.state',
options: [State.error,
State.loading]
}),
Input(),
__metadata("design:type", String)
], BlockComponent.prototype, "state", void 0);
__decorate([
PropertyApi({
description: 'Adapted block on mobile view',
path: 'ui.feature',
options: [Feature.adapted]
}),
HostBinding('attr.data-features'),
Input(),
__metadata("design:type", Array)
], BlockComponent.prototype, "features", void 0);
__decorate([
ContentApi({
selector: '#blockHelpTemplate',
description: 'Block help template'
}),
ContentChild('blockHelpTemplate'),
__metadata("design:type", TemplateRef)
], BlockComponent.prototype, "blockHelpTemplate", void 0);
__decorate([
ContentApi({
selector: '#blockHeaderTemplate',
description: 'Block header template'
}),
ContentChild('blockHeaderTemplate'),
__metadata("design:type", TemplateRef)
], BlockComponent.prototype, "blockHeaderTemplate", void 0);
__decorate([
ContentApi({
selector: '#blockFooterTemplate',
description: 'Block footer template'
}),
ContentChild('blockFooterTemplate'),
__metadata("design:type", TemplateRef)
], BlockComponent.prototype, "blockFooterTemplate", void 0);
__decorate([
MethodApi({ description: 'Show success animation' }),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], BlockComponent.prototype, "success", null);
BlockComponent = __decorate([
Component({
selector: 'jnt-block',
template: "<div child-of=\"jnt-block-host\" *ngIf=\"state === ui.state.loading\" data-state>\n <jnt-spinner child-of=\"jnt-block-host\" [size]=\"ui.size.large\"></jnt-spinner>\n</div>\n<div child-of=\"jnt-block-host\" *ngIf=\"state === ui.state.error\" data-state>\n <jnt-icon child-of=\"jnt-block-host\" [icon]=\"ui.icons.sad\"></jnt-icon>\n</div>\n<div child-of=\"jnt-block-host\" *ngIf=\"_state.success\" [@success]=\"_state.success\" data-state>\n <jnt-icon child-of=\"jnt-block-host\" [icon]=\"ui.icons.animated.success\"></jnt-icon>\n</div>\n\n<div child-of=\"jnt-block-host\" data-help *ngIf=\"!!blockHelpTemplate\"\n [jntPopover]=\"{\n contentTemplate: blockHelpTemplate,\n trigger: ui.trigger.click,\n position: breakpoint.current !== ui.breakpoint.mobile ? ui.position.right : ui.position.bottom\n }\">\n <jnt-icon child-of=\"jnt-block-host\" [icon]=\"ui.icons.question\"></jnt-icon>\n</div>\n\n<jnt-stack child-of=\"jnt-block-host\" data-block [align]=\"ui.align.stretch\" [gutter]=\"spacing\">\n <div child-of=\"jnt-block-host\" *ngIf=\"!!title && !blockHeaderTemplate\" data-title>\n {{title}}\n </div>\n\n <ng-container *ngIf=\"!!blockHeaderTemplate\">\n <ng-container *ngTemplateOutlet=\"blockHeaderTemplate\"></ng-container>\n </ng-container>\n\n <div child-of=\"jnt-block-host\" data-body>\n <ng-content></ng-content>\n </div>\n\n <div child-of=\"jnt-block-host\" *ngIf=\"!!blockFooterTemplate\" data-footer>\n <ng-container *ngTemplateOutlet=\"blockFooterTemplate\"></ng-container>\n </div>\n</jnt-stack>",
animations: [
trigger('success', [
state('void', style({
opacity: 0
})),
state('*', style({
opacity: 1
})),
transition('void <=> *', [
animate('.3s ease-in-out')
]),
]),
]
}),
__metadata("design:paramtypes", [BreakpointService])
], BlockComponent);
return BlockComponent;
}());
export { BlockComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/layout/block/block.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { Component, ContentChild, HostBinding, Input, TemplateRef } from '@angular/core';\nimport { BreakpointService } from '../responsive/breakpoint.service';\nimport { ContentApi, MethodApi, PropertyApi } from '../../core/decorators/api';\nimport { Feature } from '../../core/enums/feature';\nimport { Gutter } from '../../core/enums/gutter';\nimport { State } from '../../core/enums/state';\nimport { UI } from '../../core/enums/ui';\nimport { Width } from '../../core/enums/width';\n\n@Component({\n  selector: 'jnt-block',\n  templateUrl: './block.encapsulated.html',\n  animations: [\n    trigger('success', [\n        state(\n          'void',\n          style({\n            opacity: 0\n          })\n        ),\n        state(\n          '*',\n          style({\n            opacity: 1\n          })\n        ),\n        transition(\n          'void <=> *',\n          [\n            animate('.3s ease-in-out')\n          ]\n        ),\n      ]\n    ),\n  ]\n})\nexport class BlockComponent {\n\n  ui = UI;\n\n  _state = {success: false};\n\n  @HostBinding('attr.host') readonly host = 'jnt-block-host';\n\n  @HostBinding('attr.data-has-help')\n  get hasHelp() {\n    return !!this.blockHelpTemplate;\n  }\n\n  @HostBinding('attr.data-has-header')\n  get hasHeader() {\n    return !!this.blockHeaderTemplate || !!this.title;\n  }\n\n  @HostBinding('attr.data-padding')\n  _padding = Gutter.normal;\n\n  _spacing = Gutter.normal;\n\n  @PropertyApi({\n    description: 'Title of block',\n    type: 'string'\n  })\n  @Input()\n  title: string;\n\n  @PropertyApi({\n    description: 'Padding for block',\n    path: 'ui.gutter',\n    options: [Gutter.tiny,\n      Gutter.small,\n      Gutter.normal,\n      Gutter.large,\n      Gutter.big,\n      Gutter.huge],\n    default: Gutter.normal\n  })\n  @Input() set padding(padding: Gutter) {\n    this._padding = padding || Gutter.normal;\n  }\n\n  @PropertyApi({\n    description: 'Spacing between header, body and footer',\n    path: 'ui.gutter',\n    options: [Gutter.tiny,\n      Gutter.small,\n      Gutter.normal,\n      Gutter.large,\n      Gutter.big,\n      Gutter.huge],\n    default: Gutter.normal\n  })\n  @Input() set spacing(spacing: Gutter) {\n    this._spacing = spacing || Gutter.normal;\n  }\n\n  get spacing() {\n    return this._spacing;\n  }\n\n  @PropertyApi({\n    description: 'Block width',\n    path: 'ui.width',\n    default: Width.default,\n    options: [Width.default,\n      Width.fluid]\n  })\n  @HostBinding('attr.data-width')\n  @Input()\n  width: Width = Width.default;\n\n  @PropertyApi({\n    description: 'State of block',\n    path: 'ui.state',\n    options: [State.error,\n      State.loading]\n  })\n  @Input()\n  state: State;\n\n  @PropertyApi({\n    description: 'Adapted block on mobile view',\n    path: 'ui.feature',\n    options: [Feature.adapted]\n  })\n  @HostBinding('attr.data-features')\n  @Input()\n  features: Feature[] = [];\n\n  @ContentApi({\n    selector: '#blockHelpTemplate',\n    description: 'Block help template'\n  })\n  @ContentChild('blockHelpTemplate')\n  blockHelpTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#blockHeaderTemplate',\n    description: 'Block header template'\n  })\n  @ContentChild('blockHeaderTemplate')\n  blockHeaderTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#blockFooterTemplate',\n    description: 'Block footer template'\n  })\n  @ContentChild('blockFooterTemplate')\n  blockFooterTemplate: TemplateRef<any>;\n\n  @MethodApi({description: 'Show success animation'})\n  success() {\n    this._state.success = true;\n    setTimeout(() => this._state.success = false, 2100);\n  }\n\n  constructor(public breakpoint: BreakpointService) {\n  }\n}\n"]}