com.phloxui
Version:
PhloxUI Ng2+ Framework
142 lines (141 loc) • 14.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component } from '@angular/core';
import { UserService } from '../../../../service/UserService.service';
import { APP_SWITCHER_HEADER, APP_SWITCHER_TAGLINE } from '../../../../share/Constants';
var /** @type {?} */ TYPE_NAME = "phx-app-drawer-popover";
var AppDrawerPopover = /** @class */ (function () {
function AppDrawerPopover(userService) {
var _this = this;
this.header = APP_SWITCHER_HEADER;
this.tagline = APP_SWITCHER_TAGLINE;
this.userService = userService;
var /** @type {?} */ accessibleAppProm = this.userService.getAccessibleApp();
if (accessibleAppProm !== null && accessibleAppProm !== undefined) {
accessibleAppProm.then(function (result) {
_this.appItems = result;
_this.groupAppItems = [];
_this.addedGroupItemMap = {};
if (result !== null && result !== undefined && Array.isArray(result)) {
try {
for (var result_1 = tslib_1.__values(result), result_1_1 = result_1.next(); !result_1_1.done; result_1_1 = result_1.next()) {
var item = result_1_1.value;
var /** @type {?} */ groupName = item.group;
if (groupName != null && groupName !== '') {
var /** @type {?} */ groupingItem = _this.addedGroupItemMap[groupName];
if (groupingItem != null && groupingItem !== 'undefined') {
groupingItem.items.push(item);
}
else {
var /** @type {?} */ items = [];
var /** @type {?} */ innerItem = { "groupName": groupName, "items": items };
innerItem.items.push(item);
_this.groupAppItems.push(innerItem);
_this.addedGroupItemMap[groupName] = innerItem;
}
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (result_1_1 && !result_1_1.done && (_a = result_1.return)) _a.call(result_1);
}
finally { if (e_1) throw e_1.error; }
}
}
var e_1, _a;
});
}
}
/**
* @return {?}
*/
AppDrawerPopover.prototype.isShowMore = /**
* @return {?}
*/
function () {
//! show when has many app to load just implement here
if (this.groupAppItems !== null && this.groupAppItems !== undefined && this.groupAppItems.length > 0) {
return true;
}
return false;
};
/**
* @return {?}
*/
AppDrawerPopover.prototype.getHeader = /**
* @return {?}
*/
function () {
return this.header;
};
/**
* @return {?}
*/
AppDrawerPopover.prototype.getTagline = /**
* @return {?}
*/
function () {
return this.tagline;
};
/**
* @return {?}
*/
AppDrawerPopover.prototype.getAppItems = /**
* @return {?}
*/
function () {
return this.appItems;
};
/**
* @return {?}
*/
AppDrawerPopover.prototype.getGroupAppItems = /**
* @return {?}
*/
function () {
return this.groupAppItems;
};
AppDrawerPopover.TYPE_NAME = TYPE_NAME;
AppDrawerPopover.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-app-drawer-popover\">\n <div class=\"container-fluid scroll\">\n <!--Row with single column-->\n <div class=\"row\">\n <div class=\"col-xs-12\">\n <div>\n <div class=\"row\" class=\"header\">\n <div class=\"col-md-12\">\n {{getHeader()}}\n </div>\n </div>\n <div class=\"row\" class=\"tagline\">\n <div class=\"col-md-12\">\n {{getTagline()}}\n </div>\n </div>\n </div>\n </div>\n </div>\n <br>\n \t<div *ngFor=\"let item of getGroupAppItems()\">\n \t\t{{item.groupName}}\n \t\t<hr>\n \t <div class=\"row\">\n \t <div class=\"col-xs-4 appitem\" *ngFor=\"let item2 of item.items\">\n \t\t\t\t<div class=\"container-fluid\"\n \t\t\t\t\tstyle=\"background-color: #FFFFFF; text-align: center;\">\n \t\t\t\t\t<div class=\"row\">\n \t\t\t\t\t\t<img src=\"{{item2.iconURL}}\" style=\"width: 80px;\" />\n \t\t\t\t\t</div>\n \t\t\t\t\t<div class=\"row\">{{item2.name}}</div>\n \t\t\t\t</div>\n \t\t\t</div>\n \t </div>\n \t</div>\n <br>\n <div class=\"row\" *ngIf=\"isShowMore()\">\n <div class=\"col-xs-12 more\">\n More\n </div>\n </div>\n </div>\n</div>\n"
},] },
];
/** @nocollapse */
AppDrawerPopover.ctorParameters = function () { return [
{ type: UserService, },
]; };
return AppDrawerPopover;
}());
export { AppDrawerPopover };
function AppDrawerPopover_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
AppDrawerPopover.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
AppDrawerPopover.ctorParameters;
/** @type {?} */
AppDrawerPopover.TYPE_NAME;
/** @type {?} */
AppDrawerPopover.prototype.header;
/** @type {?} */
AppDrawerPopover.prototype.tagline;
/** @type {?} */
AppDrawerPopover.prototype.appItems;
/** @type {?} */
AppDrawerPopover.prototype.groupAppItems;
/** @type {?} */
AppDrawerPopover.prototype.addedGroupItemMap;
/** @type {?} */
AppDrawerPopover.prototype.userService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AppDrawerPopover.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/page/main/switcher.internal/AppDrawerPopover.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C,OAAO,EAAE,WAAW,EAAE,MAAM,yCAAyC,CAAC;AAEtE,OAAO,EACL,mBAAmB,EAAE,oBAAoB,EAC1C,MAAM,6BAA6B,CAAC;AAErC,qBAAM,SAAS,GAAW,wBAAwB,CAAC;;IA6DjD,0BAAY,WAAwB;QAApC,iBAgCC;sBAvCwB,mBAAmB;uBAClB,oBAAoB;QAO5C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAE/B,qBAAI,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC;QAE5D,EAAE,CAAA,CAAC,iBAAiB,KAAK,IAAI,IAAI,iBAAiB,KAAK,SAAS,CAAC,CAAA,CAAC;YAChE,iBAAiB,CAAC,IAAI,CAAC,UAAC,MAAM;gBAC5B,KAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;gBACvB,KAAI,CAAC,aAAa,GAAG,EAAE,CAAC;gBACxB,KAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;gBAE5B,EAAE,CAAA,CAAC,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAA,CAAC;;wBACnE,GAAG,CAAC,CAAa,IAAA,WAAA,iBAAA,MAAM,CAAA,8BAAA;4BAAlB,IAAI,IAAI,mBAAA;4BACX,qBAAI,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;4BAC3B,EAAE,CAAC,CAAC,SAAS,IAAI,IAAI,IAAI,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC;gCAC1C,qBAAI,YAAY,GAAQ,KAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;gCAE1D,EAAE,CAAC,CAAC,YAAY,IAAI,IAAI,IAAI,YAAY,KAAK,WAAW,CAAC,CAAC,CAAC;oCACzD,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iCAC/B;gCAAC,IAAI,CAAC,CAAC;oCACN,qBAAI,KAAK,GAAU,EAAE,CAAC;oCACtB,qBAAI,SAAS,GAAG,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;oCAC3D,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oCAC3B,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;oCACnC,KAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC;iCAC/C;6BACF;yBACF;;;;;;;;;iBACF;;aAEF,CAAC,CAAC;SACJ;KACF;;;;IAEM,qCAAU;;;;;QAEf,EAAE,CAAA,CAAC,IAAI,CAAC,aAAa,KAAI,IAAI,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA,CAAC;YAClG,MAAM,CAAC,IAAI,CAAC;SACb;QAED,MAAM,CAAC,KAAK,CAAC;;;;;IAGR,oCAAS;;;;QACd,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;;;;;IAGd,qCAAU;;;;QACf,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;IAGf,sCAAW;;;;QAChB,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;;;;;IAGhB,2CAAgB;;;;QACrB,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC;;iCAjEe,SAAS;;gBAlDrD,SAAS,SAAC;oBACT,QAAQ,EAAE,MAAM,CAAC,EAAE;oBACnB,QAAQ,EAAE,SAAS;oBACnB,QAAQ,EAAE,w0CA2CX;iBACA;;;;gBAvDQ,WAAW;;2BAFpB;;SA0Da,gBAAgB","sourcesContent":["import { Component } from '@angular/core';\n\nimport { UserService } from '../../../../service/UserService.service';\nimport { PhloxAppInfo } from '../../../../component/model/PhloxAppInfo';\nimport {\n  APP_SWITCHER_HEADER, APP_SWITCHER_TAGLINE\n} from '../../../../share/Constants';\n\nconst TYPE_NAME: string = \"phx-app-drawer-popover\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-app-drawer-popover\">\n  <div class=\"container-fluid scroll\">\n       <!--Row with single column-->\n       <div class=\"row\">\n        <div class=\"col-xs-12\">\n            <div>\n              <div class=\"row\" class=\"header\">\n                  <div class=\"col-md-12\">\n                    {{getHeader()}}\n                  </div>\n              </div>\n              <div class=\"row\" class=\"tagline\">\n                  <div class=\"col-md-12\">\n                    {{getTagline()}}\n                  </div>\n              </div>\n            </div>\n        </div>\n      </div>\n      <br>\n  \t<div *ngFor=\"let item of getGroupAppItems()\">\n  \t\t{{item.groupName}}\n  \t\t<hr>\n  \t    <div class=\"row\">\n  \t      <div class=\"col-xs-4 appitem\" *ngFor=\"let item2 of item.items\">\n  \t\t\t\t<div class=\"container-fluid\"\n  \t\t\t\t\tstyle=\"background-color: #FFFFFF; text-align: center;\">\n  \t\t\t\t\t<div class=\"row\">\n  \t\t\t\t\t\t<img src=\"{{item2.iconURL}}\" style=\"width: 80px;\" />\n  \t\t\t\t\t</div>\n  \t\t\t\t\t<div class=\"row\">{{item2.name}}</div>\n  \t\t\t\t</div>\n  \t\t\t</div>\n  \t    </div>\n  \t</div>\n      <br>\n      <div class=\"row\" *ngIf=\"isShowMore()\">\n        <div class=\"col-xs-12 more\">\n          More\n        </div>\n      </div>\n    </div>\n</div>\n`\n})\nexport class AppDrawerPopover {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  private header: string = APP_SWITCHER_HEADER;\n  private tagline: string = APP_SWITCHER_TAGLINE;\n  private appItems: PhloxAppInfo[];\n  private groupAppItems: any[];\n  private addedGroupItemMap: any;\n  private userService: UserService;\n\n  constructor(userService: UserService) {\n    this.userService = userService;\n\n    let accessibleAppProm = this.userService.getAccessibleApp();\n\n    if(accessibleAppProm !== null && accessibleAppProm !== undefined){\n      accessibleAppProm.then((result) => {\n        this.appItems = result;\n        this.groupAppItems = [];\n        this.addedGroupItemMap = {};\n\n        if(result !== null && result !== undefined && Array.isArray(result)){\n          for (let item of result) {\n            let groupName = item.group;\n            if (groupName != null && groupName !== '') {\n              let groupingItem: any = this.addedGroupItemMap[groupName];\n\n              if (groupingItem != null && groupingItem !== 'undefined') {\n                groupingItem.items.push(item);\n              } else {\n                let items: any[] = [];\n                let innerItem = { \"groupName\": groupName, \"items\": items };\n                innerItem.items.push(item);\n                this.groupAppItems.push(innerItem);\n                this.addedGroupItemMap[groupName] = innerItem;\n              }\n            }\n          }\n        }\n\n      });\n    }\n  }\n\n  public isShowMore(): boolean {\n    //! show when has many app to load just implement here\n    if(this.groupAppItems!== null && this.groupAppItems !== undefined && this.groupAppItems.length > 0){\n      return true;\n    }\n\n    return false;\n  }\n\n  public getHeader(): string {\n    return this.header;\n  }\n\n  public getTagline(): string {\n    return this.tagline;\n  }\n\n  public getAppItems(): PhloxAppInfo[] {\n    return this.appItems;\n  }\n\n  public getGroupAppItems(): any[] {\n    return this.groupAppItems;\n  }\n}\n"]}