tin-spa 2.1.13 → 2.1.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/classes/Classes.mjs +11 -1
- package/esm2020/lib/components/accounts/accounts.component.mjs +57 -6
- package/esm2020/lib/components/form/form.component.mjs +3 -3
- package/esm2020/lib/components/inventory/inventory.component.mjs +1 -1
- package/esm2020/lib/components/login/login.component.mjs +6 -5
- package/esm2020/lib/components/table/table.component.mjs +17 -4
- package/esm2020/lib/components/transactions/transactDialog.component.mjs +76 -0
- package/esm2020/lib/components/transactions/transactions.component.mjs +91 -0
- package/esm2020/lib/modules/admin/admin-routing.module.mjs +3 -1
- package/esm2020/lib/services/data.service.mjs +22 -4
- package/esm2020/lib/tin-spa.module.mjs +6 -2
- package/fesm2015/tin-spa.mjs +251 -19
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +249 -19
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +14 -0
- package/lib/components/accounts/accounts.component.d.ts +21 -1
- package/lib/components/table/table.component.d.ts +2 -1
- package/lib/components/transactions/transactDialog.component.d.ts +23 -0
- package/lib/components/transactions/transactions.component.d.ts +30 -0
- package/lib/services/data.service.d.ts +7 -1
- package/lib/tin-spa.module.d.ts +7 -5
- package/package.json +1 -1
|
@@ -72,6 +72,16 @@ export class ChangeUserPassword {
|
|
|
72
72
|
this.confirmPassword = "";
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
+
export class Transaction {
|
|
76
|
+
constructor() {
|
|
77
|
+
this.transactionID = 0;
|
|
78
|
+
this.reference = "";
|
|
79
|
+
this.amount = '0';
|
|
80
|
+
this.type = 0;
|
|
81
|
+
this.date = "";
|
|
82
|
+
this.accountID = 0;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
75
85
|
export class Register {
|
|
76
86
|
constructor() {
|
|
77
87
|
this.userName = "";
|
|
@@ -214,4 +224,4 @@ export var LogLevel;
|
|
|
214
224
|
LogLevel[LogLevel["Fatal"] = 5] = "Fatal";
|
|
215
225
|
LogLevel[LogLevel["Off"] = 6] = "Off";
|
|
216
226
|
})(LogLevel || (LogLevel = {}));
|
|
217
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Classes.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/classes/Classes.ts"],"names":[],"mappings":"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AAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;CAwGF;AAGD,MAAM,CAAN,IAAY,QAQX;AARD,WAAY,QAAQ;IAClB,qCAAO,CAAA;IACP,yCAAS,CAAA;IACT,uCAAQ,CAAA;IACR,uCAAQ,CAAA;IACR,yCAAS,CAAA;IACT,yCAAS,CAAA;IACT,qCAAO,CAAA;AACT,CAAC,EARW,QAAQ,KAAR,QAAQ,QAQnB","sourcesContent":["import { Core } from \"./TinCore\";\r\n\r\nexport class Action{\r\n  method?: 'get' | 'post'\r\n  url: string;\r\n  params? : any[]\r\n  successMessage?: string\r\n  isFormData?: boolean\r\n}\r\n\r\n\r\n\r\nexport class SearchConfig {\r\n  fields: SearchField[]\r\n  searchAction?: Action\r\n}\r\n\r\nexport interface SearchField extends Field{\r\n\r\n  show?: boolean\r\n\r\n}\r\n\r\nexport class FormConfig {\r\n  fields: Field[]\r\n  mode?: string\r\n  button? : Button\r\n  multiColumn?: boolean\r\n  reset?: boolean\r\n  fileAction?: Action\r\n\r\n}\r\n\r\nexport interface Button{\r\n  name: string\r\n  visible?: (value: any) => boolean;\r\n  display?: string;\r\n  icon?: Icon;\r\n  disabled?: (value: any) => boolean;\r\n  color?: string;\r\n  tip?: string\r\n  dialog?: boolean\r\n  action?: Action\r\n  confirm?: Confirm\r\n\r\n}\r\n\r\nexport interface Confirm {\r\n  message: string\r\n}\r\n\r\nexport interface Condition{\r\n  condition?: (value: any) => boolean;\r\n}\r\n\r\nexport interface Field {\r\n  name: string;\r\n  type: 'text' | 'date' | 'datetime' | 'checkbox' | 'select' | 'multi-select' | 'money' | 'number' | 'section' | 'blank' | 'chip' | 'file' | 'file-view' | 'icon' | 'spinner';\r\n  alias?: string;\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n  defaultValue?: any\r\n  required?: boolean\r\n  min?: any\r\n  max?: any\r\n  rows?: number\r\n  span?: boolean\r\n  readonly?: boolean\r\n  hidden?: boolean\r\n  path?: string\r\n  keyFiledName?: string\r\n}\r\n\r\nexport class TableConfig{\r\n  title?: string\r\n  columns? : Column[]\r\n  minColumns?: string[]\r\n  showFilter?: boolean\r\n  elevation?: 'none' | 'low' | 'medium' | 'high'\r\n  formConfig?: FormConfig\r\n  searchConfig?: SearchConfig\r\n  tileConfig?: TileConfig\r\n  buttons?: Button[]\r\n  minButtons?: string[]\r\n  loadAction?: Action\r\n  logResponse?: boolean\r\n  greyOut?: (value: any) => boolean;\r\n}\r\nexport interface Column {\r\n  name: string;\r\n  type?: 'text' | 'date' | 'datetime' | 'checkbox' | 'select' | 'money' | 'number' | 'chip' | 'icon' | 'spinner';\r\n  alias?: string;\r\n  icon?: Icon;\r\n  icons?: Icon[];\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n\r\n}\r\n\r\nexport interface Icon{\r\n  name: string\r\n  color?: string\r\n  tip?: string\r\n  condition?: (value: any) => boolean;\r\n}\r\n\r\n\r\nexport class TileConfig{\r\n  tiles : Tile[]\r\n  loadAction?: Action\r\n  loadInit?: boolean\r\n  clickable?: boolean\r\n  // reload?: boolean\r\n}\r\nexport interface Tile {\r\n\r\n  name: string;\r\n  alias?: string;\r\n  value?: string;\r\n  color?: string;\r\n  selectedTile?: string;\r\n  hidden?: boolean;\r\n  info?: string;\r\n  prefix?: string;\r\n  suffix?: string;\r\n}\r\n\r\nexport class Step {\r\n  name: string\r\n  icon: string;\r\n}\r\n\r\n\r\n\r\nexport class ActionResponse {\r\n  name: string;\r\n  value;\r\n}\r\n\r\n\r\nexport class loginConfig {\r\n\r\n  constructor() {\r\n    this.appName = \"\";\r\n    this.selfService = false;\r\n    this.logo = \"\";\r\n    this.logoSize = \"normal\";\r\n  }\r\n\r\n  appName: string;\r\n  selfService: boolean;\r\n  logo: string;\r\n  logoSize: string;\r\n}\r\n\r\n\r\nexport class AppConfig {\r\n  constructor() {\r\n    this.appName = \"App Name\";\r\n    this.logo = \"\";\r\n    this.logoSize = \"normal\";\r\n    this.ADAuth = true;\r\n    this.localAuth = true;\r\n    this.selfService = false;\r\n    this.multitenant = false;\r\n  }\r\n  appName: string;\r\n  logo: string;\r\n  logoSize: string;\r\n  ADAuth: boolean;\r\n  localAuth: boolean;\r\n  selfService: boolean;\r\n  capItems: CapItem[];\r\n  multitenant : boolean;\r\n\r\n\r\n}\r\n\r\nexport class CapItem {\r\n\r\n  constructor() {\r\n    this.name = \"\";\r\n    this.display = \"New Cap Item\";\r\n    this.enabled = false;\r\n    this.type = \"\";\r\n    this.newLine = false;\r\n    this.showMenu = true;\r\n    this.ignoreSubsDisplay = false;\r\n    this.link = \"\";\r\n    this.icon = \"navigate_next\";\r\n\r\n  }\r\n\r\n  name: string;\r\n  display: string;\r\n  enabled: boolean;\r\n  showMenu: boolean;\r\n\r\n  ignoreSubsDisplay: boolean;\r\n  type: string;\r\n  newLine: boolean;\r\n  link: string;\r\n  icon: string;\r\n  capSubItems: CapItem[];\r\n\r\n}\r\n\r\n\r\nexport class Account {\r\n  user: User;\r\n  profile: Profile;\r\n}\r\n\r\nexport class User {\r\n\r\n  constructor() {\r\n\r\n\r\n    this.userName = \"\";\r\n    this.password = \"\";\r\n    this.tries = \"0\";\r\n    this.locked = \"0\";\r\n    this.logged = \"0\";\r\n    this.disabled = \"0\";\r\n    this.changepassword = \"0\";\r\n    this.dateCreated = Core.nowDate();\r\n    this.dateUpdated = Core.nowDate();\r\n    this.token = \"\";\r\n    this.dateExpire = Core.nowDate();\r\n    this.tokenExpire = Core.nowDate();\r\n    this.authType = \"\";\r\n  }\r\n\r\n  userName:string;\r\n  password: string;\r\n  tries: string;\r\n  locked: string;\r\n  logged: string;\r\n  disabled: string;\r\n  changepassword: string;\r\n  dateCreated: string;\r\n  dateUpdated: string;\r\n  dateExpire: string;\r\n  token: string;\r\n  tokenExpire: string;\r\n\r\n  authType: string;\r\n}\r\n\r\nexport class ChangeUserPassword {\r\n\r\n  constructor() {\r\n    this.userName = \"\";\r\n    this.currentPassword = \"\";\r\n    this.newPassword = \"\";\r\n    this.confirmPassword = \"\";\r\n  }\r\n  userName: string;\r\n  currentPassword: string;\r\n  newPassword: string;\r\n  confirmPassword: string;\r\n}\r\n\r\nexport class Register {\r\n\r\n  constructor() {\r\n    this.userName = \"\";\r\n    this.roleID = 1;\r\n    this.firstName = \"\";\r\n    this.lastName = \"\";\r\n    this.email = \"\";\r\n    this.authType = \"local\";\r\n    this.password = \"\";\r\n  }\r\n\r\n  userName: string;\r\n  roleID: number;\r\n  firstName: string;\r\n  lastName: string;\r\n  email: string;\r\n  authType: string;\r\n  password: string;\r\n}\r\n\r\nexport class Profile {\r\n\r\n  constructor() {\r\n    this.profileID = \"\";\r\n    this.userName = \"\";\r\n    this.roleID = 1;\r\n    this.firstName = \"\";\r\n    this.lastName = \"\";\r\n    this.email = \"\";\r\n    this.empID = \"\";\r\n    this.arID = \"0\";\r\n    this.authType = \"\";\r\n    this.password = \"\";\r\n    this.role = new Role();\r\n  }\r\n\r\n  profileID: string;\r\n  userName: string;\r\n  roleID: number;\r\n  firstName: string;\r\n  lastName: string;\r\n  email: string;\r\n  empID: string;\r\n  arID: string;\r\n  authType: string;\r\n  password: string;\r\n  role: Role\r\n}\r\n\r\n\r\nexport class Role {\r\n\r\n  constructor() {\r\n    this.roleID = 0;\r\n    this.roleName = \"New Role\";\r\n    this.cap1 = false;\r\n    this.cap2 = false;\r\n    this.cap3 = false;\r\n    this.cap4 = false;\r\n    this.cap5 = false;\r\n    this.cap6 = false;\r\n    this.cap7 = false;\r\n    this.cap8 = false;\r\n    this.cap9 = false;\r\n    this.cap10 = false;\r\n    this.cap11 = false;\r\n    this.cap12 = false;\r\n    this.cap13 = false;\r\n    this.cap14 = false;\r\n    this.cap15 = false;\r\n    this.cap16 = false;\r\n    this.cap17 = false;\r\n    this.cap18 = false;\r\n    this.cap19 = false;\r\n    this.cap20 = false;\r\n    this.cap21 = false;\r\n    this.cap22 = false;\r\n    this.cap23 = false;\r\n    this.cap24 = false;\r\n    this.cap25 = false;\r\n    this.cap26 = false;\r\n    this.cap27 = false;\r\n    this.cap28 = false;\r\n    this.cap29 = false;\r\n    this.cap30 = false;\r\n    this.cap31 = false;\r\n    this.cap32 = false;\r\n    this.cap33 = false;\r\n    this.cap34 = false;\r\n    this.cap35 = false;\r\n    this.cap36 = false;\r\n    this.cap37 = false;\r\n    this.cap38 = false;\r\n    this.cap39 = false;\r\n    this.cap40 = false;\r\n    this.cap41 = false;\r\n    this.cap42 = false;\r\n    this.cap43 = false;\r\n    this.cap44 = false;\r\n    this.cap45 = false;\r\n    this.cap46 = false;\r\n    this.cap47 = false;\r\n    this.cap48 = false;\r\n    this.cap49 = false;\r\n    this.cap50 = false;\r\n    this.cap51 = false;\r\n    this.cap52 = false;\r\n    this.cap53 = false;\r\n    this.cap54 = false;\r\n    this.cap55 = false;\r\n    this.cap56 = false;\r\n    this.cap57 = false;\r\n    this.cap58 = false;\r\n    this.cap59 = false;\r\n    this.cap60 = false;\r\n    this.cap61 = false;\r\n    this.cap62 = false;\r\n    this.cap63 = false;\r\n    this.cap64 = false;\r\n    this.cap65 = false;\r\n    this.cap66 = false;\r\n    this.cap67 = false;\r\n    this.cap68 = false;\r\n    this.cap69 = false;\r\n    this.cap70 = false;\r\n    this.cap71 = false;\r\n    this.cap72 = false;\r\n    this.cap73 = false;\r\n    this.cap74 = false;\r\n    this.cap75 = false;\r\n    this.cap76 = false;\r\n    this.cap77 = false;\r\n    this.cap78 = false;\r\n    this.cap79 = false;\r\n    this.cap80 = false;\r\n    this.cap81 = false;\r\n    this.cap82 = false;\r\n    this.cap83 = false;\r\n    this.cap84 = false;\r\n    this.cap85 = false;\r\n    this.cap86 = false;\r\n    this.cap87 = false;\r\n    this.cap88 = false;\r\n    this.cap89 = false;\r\n    this.cap90 = false;\r\n    this.cap91 = false;\r\n    this.cap92 = false;\r\n    this.cap93 = false;\r\n    this.cap94 = false;\r\n    this.cap95 = false;\r\n    this.cap96 = false;\r\n    this.cap97 = false;\r\n    this.cap98 = false;\r\n    this.cap99 = false;\r\n    this.cap100 = false;\r\n  }\r\n\r\n  roleID: number;\r\n  roleName: string;\r\n  cap1: boolean;\r\n  cap2: boolean;\r\n  cap3: boolean;\r\n  cap4: boolean;\r\n  cap5: boolean;\r\n  cap6: boolean;\r\n  cap7: boolean;\r\n  cap8: boolean;\r\n  cap9: boolean;\r\n  cap10: boolean;\r\n  cap11: boolean;\r\n  cap12: boolean;\r\n  cap13: boolean;\r\n  cap14: boolean;\r\n  cap15: boolean;\r\n  cap16: boolean;\r\n  cap17: boolean;\r\n  cap18: boolean;\r\n  cap19: boolean;\r\n  cap20: boolean;\r\n  cap21: boolean;\r\n  cap22: boolean;\r\n  cap23: boolean;\r\n  cap24: boolean;\r\n  cap25: boolean;\r\n  cap26: boolean;\r\n  cap27: boolean;\r\n  cap28: boolean;\r\n  cap29: boolean;\r\n  cap30: boolean;\r\n  cap31: boolean;\r\n  cap32: boolean;\r\n  cap33: boolean;\r\n  cap34: boolean;\r\n  cap35: boolean;\r\n  cap36: boolean;\r\n  cap37: boolean;\r\n  cap38: boolean;\r\n  cap39: boolean;\r\n  cap40: boolean;\r\n  cap41: boolean;\r\n  cap42: boolean;\r\n  cap43: boolean;\r\n  cap44: boolean;\r\n  cap45: boolean;\r\n  cap46: boolean;\r\n  cap47: boolean;\r\n  cap48: boolean;\r\n  cap49: boolean;\r\n  cap50: boolean;\r\n  cap51: boolean;\r\n  cap52: boolean;\r\n  cap53: boolean;\r\n  cap54: boolean;\r\n  cap55: boolean;\r\n  cap56: boolean;\r\n  cap57: boolean;\r\n  cap58: boolean;\r\n  cap59: boolean;\r\n  cap60: boolean;\r\n  cap61: boolean;\r\n  cap62: boolean;\r\n  cap63: boolean;\r\n  cap64: boolean;\r\n  cap65: boolean;\r\n  cap66: boolean;\r\n  cap67: boolean;\r\n  cap68: boolean;\r\n  cap69: boolean;\r\n  cap70: boolean;\r\n  cap71: boolean;\r\n  cap72: boolean;\r\n  cap73: boolean;\r\n  cap74: boolean;\r\n  cap75: boolean;\r\n  cap76: boolean;\r\n  cap77: boolean;\r\n  cap78: boolean;\r\n  cap79: boolean;\r\n  cap80: boolean;\r\n  cap81: boolean;\r\n  cap82: boolean;\r\n  cap83: boolean;\r\n  cap84: boolean;\r\n  cap85: boolean;\r\n  cap86: boolean;\r\n  cap87: boolean;\r\n  cap88: boolean;\r\n  cap89: boolean;\r\n  cap90: boolean;\r\n  cap91: boolean;\r\n  cap92: boolean;\r\n  cap93: boolean;\r\n  cap94: boolean;\r\n  cap95: boolean;\r\n  cap96: boolean;\r\n  cap97: boolean;\r\n  cap98: boolean;\r\n  cap99: boolean;\r\n  cap100: boolean;\r\n}\r\n\r\n\r\nexport enum LogLevel {\r\n  All = 0,\r\n  Debug = 1,\r\n  Info = 2,\r\n  Warn = 3,\r\n  Error = 4,\r\n  Fatal = 5,\r\n  Off = 6,\r\n}\r\n"]}
|
|
227
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Classes.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/classes/Classes.ts"],"names":[],"mappings":"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C,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;CAwGF;AAGD,MAAM,CAAN,IAAY,QAQX;AARD,WAAY,QAAQ;IAClB,qCAAO,CAAA;IACP,yCAAS,CAAA;IACT,uCAAQ,CAAA;IACR,uCAAQ,CAAA;IACR,yCAAS,CAAA;IACT,yCAAS,CAAA;IACT,qCAAO,CAAA;AACT,CAAC,EARW,QAAQ,KAAR,QAAQ,QAQnB","sourcesContent":["import { Core } from \"./TinCore\";\r\n\r\n\r\n\r\nexport class Action{\r\n  method?: 'get' | 'post'\r\n  url: string;\r\n  params? : any[]\r\n  successMessage?: string\r\n  isFormData?: boolean\r\n}\r\n\r\n\r\n\r\nexport class SearchConfig {\r\n  fields: SearchField[]\r\n  searchAction?: Action\r\n}\r\n\r\nexport interface SearchField extends Field{\r\n\r\n  show?: boolean\r\n\r\n}\r\n\r\nexport class FormConfig {\r\n  fields: Field[]\r\n  mode?: string\r\n  button? : Button\r\n  multiColumn?: boolean\r\n  reset?: boolean\r\n  fileAction?: Action\r\n\r\n}\r\n\r\nexport interface Button{\r\n  name: string\r\n  visible?: (value: any) => boolean;\r\n  display?: string;\r\n  icon?: Icon;\r\n  disabled?: (value: any) => boolean;\r\n  color?: string;\r\n  tip?: string\r\n  dialog?: boolean\r\n  action?: Action\r\n  confirm?: Confirm\r\n\r\n}\r\n\r\nexport interface Confirm {\r\n  message: string\r\n}\r\n\r\nexport interface Condition{\r\n  condition?: (value: any) => boolean;\r\n}\r\n\r\nexport interface Field {\r\n  name: string;\r\n  type: 'text' | 'date' | 'datetime' | 'checkbox' | 'select' | 'multi-select' | 'money' | 'number' | 'section' | 'blank' | 'chip' | 'file' | 'file-view' | 'icon' | 'spinner';\r\n  alias?: string;\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n  defaultValue?: any\r\n  required?: boolean\r\n  min?: any\r\n  max?: any\r\n  rows?: number\r\n  span?: boolean\r\n  readonly?: boolean\r\n  hidden?: boolean\r\n  path?: string\r\n  keyFiledName?: string\r\n}\r\n\r\nexport class TableConfig{\r\n  title?: string\r\n  columns? : Column[]\r\n  minColumns?: string[]\r\n  showFilter?: boolean\r\n  elevation?: 'none' | 'low' | 'medium' | 'high'\r\n  formConfig?: FormConfig\r\n  searchConfig?: SearchConfig\r\n  tileConfig?: TileConfig\r\n  buttons?: Button[]\r\n  minButtons?: string[]\r\n  loadAction?: Action\r\n  logResponse?: boolean\r\n  greyOut?: (value: any) => boolean;\r\n}\r\nexport interface Column {\r\n  name: string;\r\n  type?: 'text' | 'date' | 'datetime' | 'checkbox' | 'select' | 'money' | 'number' | 'chip' | 'icon' | 'spinner';\r\n  alias?: string;\r\n  icon?: Icon;\r\n  color?: Color;\r\n  icons?: Icon[];\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n\r\n}\r\n\r\nexport interface Icon{\r\n  name: string\r\n  color?: string\r\n  tip?: string\r\n  condition?: (value: any) => boolean;\r\n}\r\n\r\nexport interface Color {\r\n  name: string\r\n  condition?: (value: any) => boolean;\r\n}\r\n\r\n\r\nexport class TileConfig{\r\n  tiles : Tile[]\r\n  loadAction?: Action\r\n  loadInit?: boolean\r\n  clickable?: boolean\r\n  // reload?: boolean\r\n}\r\nexport interface Tile {\r\n\r\n  name: string;\r\n  alias?: string;\r\n  value?: string;\r\n  color?: string;\r\n  selectedTile?: string;\r\n  hidden?: boolean;\r\n  info?: string;\r\n  prefix?: string;\r\n  suffix?: string;\r\n}\r\n\r\nexport class Step {\r\n  name: string\r\n  icon: string;\r\n}\r\n\r\n\r\n\r\nexport class ActionResponse {\r\n  name: string;\r\n  value;\r\n}\r\n\r\n\r\nexport class loginConfig {\r\n\r\n  constructor() {\r\n    this.appName = \"\";\r\n    this.selfService = false;\r\n    this.logo = \"\";\r\n    this.logoSize = \"normal\";\r\n  }\r\n\r\n  appName: string;\r\n  selfService: boolean;\r\n  logo: string;\r\n  logoSize: string;\r\n}\r\n\r\n\r\nexport class AppConfig {\r\n  constructor() {\r\n    this.appName = \"App Name\";\r\n    this.logo = \"\";\r\n    this.logoSize = \"normal\";\r\n    this.ADAuth = true;\r\n    this.localAuth = true;\r\n    this.selfService = false;\r\n    this.multitenant = false;\r\n  }\r\n  appName: string;\r\n  logo: string;\r\n  logoSize: string;\r\n  ADAuth: boolean;\r\n  localAuth: boolean;\r\n  selfService: boolean;\r\n  capItems: CapItem[];\r\n  multitenant : boolean;\r\n\r\n\r\n}\r\n\r\nexport class CapItem {\r\n\r\n  constructor() {\r\n    this.name = \"\";\r\n    this.display = \"New Cap Item\";\r\n    this.enabled = false;\r\n    this.type = \"\";\r\n    this.newLine = false;\r\n    this.showMenu = true;\r\n    this.ignoreSubsDisplay = false;\r\n    this.link = \"\";\r\n    this.icon = \"navigate_next\";\r\n\r\n  }\r\n\r\n  name: string;\r\n  display: string;\r\n  enabled: boolean;\r\n  showMenu: boolean;\r\n\r\n  ignoreSubsDisplay: boolean;\r\n  type: string;\r\n  newLine: boolean;\r\n  link: string;\r\n  icon: string;\r\n  capSubItems: CapItem[];\r\n\r\n}\r\n\r\n\r\nexport class Account {\r\n  user: User;\r\n  profile: Profile;\r\n}\r\n\r\nexport class User {\r\n\r\n  constructor() {\r\n\r\n\r\n    this.userName = \"\";\r\n    this.password = \"\";\r\n    this.tries = \"0\";\r\n    this.locked = \"0\";\r\n    this.logged = \"0\";\r\n    this.disabled = \"0\";\r\n    this.changepassword = \"0\";\r\n    this.dateCreated = Core.nowDate();\r\n    this.dateUpdated = Core.nowDate();\r\n    this.token = \"\";\r\n    this.dateExpire = Core.nowDate();\r\n    this.tokenExpire = Core.nowDate();\r\n    this.authType = \"\";\r\n  }\r\n\r\n  userName:string;\r\n  password: string;\r\n  tries: string;\r\n  locked: string;\r\n  logged: string;\r\n  disabled: string;\r\n  changepassword: string;\r\n  dateCreated: string;\r\n  dateUpdated: string;\r\n  dateExpire: string;\r\n  token: string;\r\n  tokenExpire: string;\r\n\r\n  authType: string;\r\n}\r\n\r\nexport class ChangeUserPassword {\r\n\r\n  constructor() {\r\n    this.userName = \"\";\r\n    this.currentPassword = \"\";\r\n    this.newPassword = \"\";\r\n    this.confirmPassword = \"\";\r\n  }\r\n  userName: string;\r\n  currentPassword: string;\r\n  newPassword: string;\r\n  confirmPassword: string;\r\n}\r\n\r\nexport class Transaction {\r\n\r\n  constructor() {\r\n    this.transactionID = 0;\r\n    this.reference = \"\";\r\n    this.amount = '0';\r\n    this.type = 0;\r\n    this.date = \"\";\r\n    this.accountID = 0;\r\n  }\r\n\r\n  transactionID : number;\r\n  reference : string;\r\n  amount : string;\r\n  type: number;\r\n  date : string;\r\n  accountID : number;\r\n\r\n\r\n}\r\n\r\nexport class Register {\r\n\r\n  constructor() {\r\n    this.userName = \"\";\r\n    this.roleID = 1;\r\n    this.firstName = \"\";\r\n    this.lastName = \"\";\r\n    this.email = \"\";\r\n    this.authType = \"local\";\r\n    this.password = \"\";\r\n  }\r\n\r\n  userName: string;\r\n  roleID: number;\r\n  firstName: string;\r\n  lastName: string;\r\n  email: string;\r\n  authType: string;\r\n  password: string;\r\n}\r\n\r\nexport class Profile {\r\n\r\n  constructor() {\r\n    this.profileID = \"\";\r\n    this.userName = \"\";\r\n    this.roleID = 1;\r\n    this.firstName = \"\";\r\n    this.lastName = \"\";\r\n    this.email = \"\";\r\n    this.empID = \"\";\r\n    this.arID = \"0\";\r\n    this.authType = \"\";\r\n    this.password = \"\";\r\n    this.role = new Role();\r\n  }\r\n\r\n  profileID: string;\r\n  userName: string;\r\n  roleID: number;\r\n  firstName: string;\r\n  lastName: string;\r\n  email: string;\r\n  empID: string;\r\n  arID: string;\r\n  authType: string;\r\n  password: string;\r\n  role: Role\r\n}\r\n\r\n\r\nexport class Role {\r\n\r\n  constructor() {\r\n    this.roleID = 0;\r\n    this.roleName = \"New Role\";\r\n    this.cap1 = false;\r\n    this.cap2 = false;\r\n    this.cap3 = false;\r\n    this.cap4 = false;\r\n    this.cap5 = false;\r\n    this.cap6 = false;\r\n    this.cap7 = false;\r\n    this.cap8 = false;\r\n    this.cap9 = false;\r\n    this.cap10 = false;\r\n    this.cap11 = false;\r\n    this.cap12 = false;\r\n    this.cap13 = false;\r\n    this.cap14 = false;\r\n    this.cap15 = false;\r\n    this.cap16 = false;\r\n    this.cap17 = false;\r\n    this.cap18 = false;\r\n    this.cap19 = false;\r\n    this.cap20 = false;\r\n    this.cap21 = false;\r\n    this.cap22 = false;\r\n    this.cap23 = false;\r\n    this.cap24 = false;\r\n    this.cap25 = false;\r\n    this.cap26 = false;\r\n    this.cap27 = false;\r\n    this.cap28 = false;\r\n    this.cap29 = false;\r\n    this.cap30 = false;\r\n    this.cap31 = false;\r\n    this.cap32 = false;\r\n    this.cap33 = false;\r\n    this.cap34 = false;\r\n    this.cap35 = false;\r\n    this.cap36 = false;\r\n    this.cap37 = false;\r\n    this.cap38 = false;\r\n    this.cap39 = false;\r\n    this.cap40 = false;\r\n    this.cap41 = false;\r\n    this.cap42 = false;\r\n    this.cap43 = false;\r\n    this.cap44 = false;\r\n    this.cap45 = false;\r\n    this.cap46 = false;\r\n    this.cap47 = false;\r\n    this.cap48 = false;\r\n    this.cap49 = false;\r\n    this.cap50 = false;\r\n    this.cap51 = false;\r\n    this.cap52 = false;\r\n    this.cap53 = false;\r\n    this.cap54 = false;\r\n    this.cap55 = false;\r\n    this.cap56 = false;\r\n    this.cap57 = false;\r\n    this.cap58 = false;\r\n    this.cap59 = false;\r\n    this.cap60 = false;\r\n    this.cap61 = false;\r\n    this.cap62 = false;\r\n    this.cap63 = false;\r\n    this.cap64 = false;\r\n    this.cap65 = false;\r\n    this.cap66 = false;\r\n    this.cap67 = false;\r\n    this.cap68 = false;\r\n    this.cap69 = false;\r\n    this.cap70 = false;\r\n    this.cap71 = false;\r\n    this.cap72 = false;\r\n    this.cap73 = false;\r\n    this.cap74 = false;\r\n    this.cap75 = false;\r\n    this.cap76 = false;\r\n    this.cap77 = false;\r\n    this.cap78 = false;\r\n    this.cap79 = false;\r\n    this.cap80 = false;\r\n    this.cap81 = false;\r\n    this.cap82 = false;\r\n    this.cap83 = false;\r\n    this.cap84 = false;\r\n    this.cap85 = false;\r\n    this.cap86 = false;\r\n    this.cap87 = false;\r\n    this.cap88 = false;\r\n    this.cap89 = false;\r\n    this.cap90 = false;\r\n    this.cap91 = false;\r\n    this.cap92 = false;\r\n    this.cap93 = false;\r\n    this.cap94 = false;\r\n    this.cap95 = false;\r\n    this.cap96 = false;\r\n    this.cap97 = false;\r\n    this.cap98 = false;\r\n    this.cap99 = false;\r\n    this.cap100 = false;\r\n  }\r\n\r\n  roleID: number;\r\n  roleName: string;\r\n  cap1: boolean;\r\n  cap2: boolean;\r\n  cap3: boolean;\r\n  cap4: boolean;\r\n  cap5: boolean;\r\n  cap6: boolean;\r\n  cap7: boolean;\r\n  cap8: boolean;\r\n  cap9: boolean;\r\n  cap10: boolean;\r\n  cap11: boolean;\r\n  cap12: boolean;\r\n  cap13: boolean;\r\n  cap14: boolean;\r\n  cap15: boolean;\r\n  cap16: boolean;\r\n  cap17: boolean;\r\n  cap18: boolean;\r\n  cap19: boolean;\r\n  cap20: boolean;\r\n  cap21: boolean;\r\n  cap22: boolean;\r\n  cap23: boolean;\r\n  cap24: boolean;\r\n  cap25: boolean;\r\n  cap26: boolean;\r\n  cap27: boolean;\r\n  cap28: boolean;\r\n  cap29: boolean;\r\n  cap30: boolean;\r\n  cap31: boolean;\r\n  cap32: boolean;\r\n  cap33: boolean;\r\n  cap34: boolean;\r\n  cap35: boolean;\r\n  cap36: boolean;\r\n  cap37: boolean;\r\n  cap38: boolean;\r\n  cap39: boolean;\r\n  cap40: boolean;\r\n  cap41: boolean;\r\n  cap42: boolean;\r\n  cap43: boolean;\r\n  cap44: boolean;\r\n  cap45: boolean;\r\n  cap46: boolean;\r\n  cap47: boolean;\r\n  cap48: boolean;\r\n  cap49: boolean;\r\n  cap50: boolean;\r\n  cap51: boolean;\r\n  cap52: boolean;\r\n  cap53: boolean;\r\n  cap54: boolean;\r\n  cap55: boolean;\r\n  cap56: boolean;\r\n  cap57: boolean;\r\n  cap58: boolean;\r\n  cap59: boolean;\r\n  cap60: boolean;\r\n  cap61: boolean;\r\n  cap62: boolean;\r\n  cap63: boolean;\r\n  cap64: boolean;\r\n  cap65: boolean;\r\n  cap66: boolean;\r\n  cap67: boolean;\r\n  cap68: boolean;\r\n  cap69: boolean;\r\n  cap70: boolean;\r\n  cap71: boolean;\r\n  cap72: boolean;\r\n  cap73: boolean;\r\n  cap74: boolean;\r\n  cap75: boolean;\r\n  cap76: boolean;\r\n  cap77: boolean;\r\n  cap78: boolean;\r\n  cap79: boolean;\r\n  cap80: boolean;\r\n  cap81: boolean;\r\n  cap82: boolean;\r\n  cap83: boolean;\r\n  cap84: boolean;\r\n  cap85: boolean;\r\n  cap86: boolean;\r\n  cap87: boolean;\r\n  cap88: boolean;\r\n  cap89: boolean;\r\n  cap90: boolean;\r\n  cap91: boolean;\r\n  cap92: boolean;\r\n  cap93: boolean;\r\n  cap94: boolean;\r\n  cap95: boolean;\r\n  cap96: boolean;\r\n  cap97: boolean;\r\n  cap98: boolean;\r\n  cap99: boolean;\r\n  cap100: boolean;\r\n}\r\n\r\n\r\nexport enum LogLevel {\r\n  All = 0,\r\n  Debug = 1,\r\n  Info = 2,\r\n  Warn = 3,\r\n  Error = 4,\r\n  Fatal = 5,\r\n  Off = 6,\r\n}\r\n"]}
|
|
@@ -1,14 +1,65 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/router";
|
|
5
|
+
import * as i2 from "../../services/data.service";
|
|
6
|
+
import * as i3 from "../../services/message.service";
|
|
7
|
+
import * as i4 from "../../services/auth.service";
|
|
8
|
+
import * as i5 from "@angular/material/dialog";
|
|
9
|
+
import * as i6 from "../table/table.component";
|
|
3
10
|
export class AccountsComponent {
|
|
4
|
-
constructor() {
|
|
11
|
+
constructor(router, dataService, messageService, authService, dialog) {
|
|
12
|
+
this.router = router;
|
|
13
|
+
this.dataService = dataService;
|
|
14
|
+
this.messageService = messageService;
|
|
15
|
+
this.authService = authService;
|
|
16
|
+
this.dialog = dialog;
|
|
17
|
+
this.reload = new Subject();
|
|
18
|
+
this.currencies = [
|
|
19
|
+
{ name: 'USD', value: 'USD' },
|
|
20
|
+
{ name: 'ZAR', value: 'ZAR' },
|
|
21
|
+
{ name: 'ZWL', value: 'ZWL' },
|
|
22
|
+
];
|
|
23
|
+
this.formConfig = {
|
|
24
|
+
fields: [
|
|
25
|
+
{ name: 'name', type: 'text', required: true },
|
|
26
|
+
{ name: 'description', required: true, type: 'text' },
|
|
27
|
+
{ name: 'currency', required: true, type: 'select', readonly: true, options: this.currencies },
|
|
28
|
+
],
|
|
29
|
+
reset: true,
|
|
30
|
+
};
|
|
31
|
+
this.config = {
|
|
32
|
+
showFilter: true,
|
|
33
|
+
minColumns: ['name'],
|
|
34
|
+
logResponse: true,
|
|
35
|
+
columns: [
|
|
36
|
+
{ name: 'name', type: 'text' },
|
|
37
|
+
{ name: 'description', type: 'text' },
|
|
38
|
+
{ name: 'currency', type: 'text' },
|
|
39
|
+
{ name: 'balance', type: 'money', },
|
|
40
|
+
],
|
|
41
|
+
buttons: [
|
|
42
|
+
{ name: 'list', icon: { name: 'format_list_bulleted' } },
|
|
43
|
+
{ name: 'create', display: 'Create', dialog: true, action: { url: 'general/accounts?action=create', method: 'post' } },
|
|
44
|
+
{ name: 'edit', dialog: true, action: { url: 'general/accounts?action=edit', method: 'post' } },
|
|
45
|
+
{ name: 'delete', dialog: true, action: { url: 'general/accounts?action=delete', method: 'post' } },
|
|
46
|
+
],
|
|
47
|
+
loadAction: { url: 'general/accounts/x' },
|
|
48
|
+
formConfig: this.formConfig
|
|
49
|
+
};
|
|
50
|
+
}
|
|
5
51
|
ngOnInit() {
|
|
6
52
|
}
|
|
53
|
+
clicked(x) {
|
|
54
|
+
if (x.name == "list") {
|
|
55
|
+
this.dataService.NavigateWithValue("home/admin/transactions", x.data.accountID);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
7
58
|
}
|
|
8
|
-
AccountsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AccountsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
-
AccountsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AccountsComponent, selector: "spa-accounts", ngImport: i0, template: "<
|
|
59
|
+
AccountsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AccountsComponent, deps: [{ token: i1.Router }, { token: i2.DataServiceLib }, { token: i3.MessageService }, { token: i4.AuthService }, { token: i5.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
+
AccountsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AccountsComponent, selector: "spa-accounts", ngImport: i0, template: "<h4>Accounts</h4>\n<hr>\n\n\n<div class=\"mt-3\" style=\" font-size: 14px;\">\n <spa-table [config]=\"config\" (actionClick)=\"clicked($event)\" [reload]=\"reload\"></spa-table>\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: i6.TableComponent, selector: "spa-table", inputs: ["data", "config", "reload"], outputs: ["dataLoad", "refreshClick", "searchClick", "createClick", "actionClick", "inputChange"] }] });
|
|
10
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AccountsComponent, decorators: [{
|
|
11
62
|
type: Component,
|
|
12
|
-
args: [{ selector: 'spa-accounts', template: "<
|
|
13
|
-
}], ctorParameters: function () { return []; } });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
args: [{ selector: 'spa-accounts', template: "<h4>Accounts</h4>\n<hr>\n\n\n<div class=\"mt-3\" style=\" font-size: 14px;\">\n <spa-table [config]=\"config\" (actionClick)=\"clicked($event)\" [reload]=\"reload\"></spa-table>\n</div>\n" }]
|
|
64
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.DataServiceLib }, { type: i3.MessageService }, { type: i4.AuthService }, { type: i5.MatDialog }]; } });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudHMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvYWNjb3VudHMvYWNjb3VudHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvYWNjb3VudHMvYWNjb3VudHMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQU9sRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7Ozs7OztBQVEvQixNQUFNLE9BQU8saUJBQWlCO0lBRTVCLFlBQW1CLE1BQWMsRUFBUyxXQUEyQixFQUFVLGNBQThCLEVBQVMsV0FBd0IsRUFBUyxNQUFpQjtRQUFySixXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQVMsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBQVUsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQVMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFXO1FBS3hLLFdBQU0sR0FBcUIsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQVd6QyxlQUFVLEdBQUc7WUFDWCxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRTtZQUM3QixFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRTtZQUM3QixFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRTtTQUM5QixDQUFBO1FBRUQsZUFBVSxHQUFlO1lBRXZCLE1BQU0sRUFBRTtnQkFDTixFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUcsSUFBSSxFQUFFO2dCQUMvQyxFQUFFLElBQUksRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFO2dCQUNyRCxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRyxJQUFJLEVBQUUsT0FBTyxFQUFHLElBQUksQ0FBQyxVQUFVLEVBQUU7YUFDakc7WUFFRCxLQUFLLEVBQUUsSUFBSTtTQUNaLENBQUE7UUFFRCxXQUFNLEdBQWdCO1lBQ3BCLFVBQVUsRUFBRSxJQUFJO1lBQ2hCLFVBQVUsRUFBRSxDQUFDLE1BQU0sQ0FBQztZQUNwQixXQUFXLEVBQUUsSUFBSTtZQUVqQixPQUFPLEVBQUU7Z0JBQ1AsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUU7Z0JBQzlCLEVBQUUsSUFBSSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFO2dCQUNyQyxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRTtnQkFDbEMsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxPQUFPLEdBQUc7YUFDcEM7WUFFRCxPQUFPLEVBQUU7Z0JBQ1AsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFLElBQUksRUFBQyxzQkFBc0IsRUFBQyxFQUFFO2dCQUV0RCxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxFQUFFLEdBQUcsRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQUU7Z0JBQ3RILEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxFQUFFLEdBQUcsRUFBRSw4QkFBOEIsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQUU7Z0JBQy9GLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxFQUFFLEdBQUcsRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQUU7YUFDcEc7WUFFRCxVQUFVLEVBQUUsRUFBRSxHQUFHLEVBQUUsb0JBQW9CLEVBQUU7WUFFekMsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO1NBRTVCLENBQUE7SUF6RDJLLENBQUM7SUFFN0ssUUFBUTtJQUNSLENBQUM7SUFJRCxPQUFPLENBQUMsQ0FBQztRQUVQLElBQUksQ0FBQyxDQUFDLElBQUksSUFBSSxNQUFNLEVBQUU7WUFFcEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyx5QkFBeUIsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFBO1NBQ2hGO0lBQ0gsQ0FBQzs7OEdBZlUsaUJBQWlCO2tHQUFqQixpQkFBaUIsb0RDZjlCLDhMQU9BOzJGRFFhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERhdGFTZXJ2aWNlTGliIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZGF0YS5zZXJ2aWNlJztcbmltcG9ydCB7IEZvcm1Db25maWcsIFRhYmxlQ29uZmlnIH0gZnJvbSAnLi4vLi4vY2xhc3Nlcy9DbGFzc2VzJztcbmltcG9ydCB7IE1lc3NhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbWVzc2FnZS5zZXJ2aWNlJztcbmltcG9ydCB7IEF1dGhTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvYXV0aC5zZXJ2aWNlJztcbi8vIGltcG9ydCB7IHF1YW50aXR5RGlhbG9nIH0gZnJvbSAnLi9xdWFudGl0eURpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NwYS1hY2NvdW50cycsXG4gIHRlbXBsYXRlVXJsOiAnLi9hY2NvdW50cy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2FjY291bnRzLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBBY2NvdW50c0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHJvdXRlcjogUm91dGVyLHByaXZhdGUgZGF0YVNlcnZpY2U6IERhdGFTZXJ2aWNlTGliLCBwcml2YXRlIG1lc3NhZ2VTZXJ2aWNlOiBNZXNzYWdlU2VydmljZSwgcHVibGljIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSwgcHVibGljIGRpYWxvZzogTWF0RGlhbG9nKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgfVxuXG4gIHJlbG9hZDogU3ViamVjdDxib29sZWFuPiA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgY2xpY2tlZCh4KSB7XG5cbiAgICBpZiAoeC5uYW1lID09IFwibGlzdFwiKSB7XG5cbiAgICAgIHRoaXMuZGF0YVNlcnZpY2UuTmF2aWdhdGVXaXRoVmFsdWUoXCJob21lL2FkbWluL3RyYW5zYWN0aW9uc1wiLCB4LmRhdGEuYWNjb3VudElEKVxuICAgIH1cbiAgfVxuXG5cbiAgY3VycmVuY2llcyA9IFtcbiAgICB7IG5hbWU6ICdVU0QnLCB2YWx1ZTogJ1VTRCcgfSxcbiAgICB7IG5hbWU6ICdaQVInLCB2YWx1ZTogJ1pBUicgfSxcbiAgICB7IG5hbWU6ICdaV0wnLCB2YWx1ZTogJ1pXTCcgfSxcbiAgXVxuXG4gIGZvcm1Db25maWc6IEZvcm1Db25maWcgPSB7XG5cbiAgICBmaWVsZHM6IFtcbiAgICAgIHsgbmFtZTogJ25hbWUnLCB0eXBlOiAndGV4dCcsIHJlcXVpcmVkIDogdHJ1ZSB9LFxuICAgICAgeyBuYW1lOiAnZGVzY3JpcHRpb24nLCByZXF1aXJlZDogdHJ1ZSwgdHlwZTogJ3RleHQnIH0sXG4gICAgICB7IG5hbWU6ICdjdXJyZW5jeScsIHJlcXVpcmVkOiB0cnVlLCB0eXBlOiAnc2VsZWN0JywgcmVhZG9ubHkgOiB0cnVlLCBvcHRpb25zIDogdGhpcy5jdXJyZW5jaWVzIH0sXG4gICAgXSxcblxuICAgIHJlc2V0OiB0cnVlLFxuICB9XG5cbiAgY29uZmlnOiBUYWJsZUNvbmZpZyA9IHtcbiAgICBzaG93RmlsdGVyOiB0cnVlLFxuICAgIG1pbkNvbHVtbnM6IFsnbmFtZSddLFxuICAgIGxvZ1Jlc3BvbnNlOiB0cnVlLFxuXG4gICAgY29sdW1uczogW1xuICAgICAgeyBuYW1lOiAnbmFtZScsIHR5cGU6ICd0ZXh0JyB9LFxuICAgICAgeyBuYW1lOiAnZGVzY3JpcHRpb24nLCB0eXBlOiAndGV4dCcgfSxcbiAgICAgIHsgbmFtZTogJ2N1cnJlbmN5JywgdHlwZTogJ3RleHQnIH0sXG4gICAgICB7IG5hbWU6ICdiYWxhbmNlJywgdHlwZTogJ21vbmV5JywgfSxcbiAgICBdLFxuXG4gICAgYnV0dG9uczogW1xuICAgICAgeyBuYW1lOiAnbGlzdCcsIGljb246IHsgbmFtZTonZm9ybWF0X2xpc3RfYnVsbGV0ZWQnfSB9LFxuXG4gICAgICB7IG5hbWU6ICdjcmVhdGUnLCBkaXNwbGF5OiAnQ3JlYXRlJywgZGlhbG9nOiB0cnVlLCBhY3Rpb246IHsgdXJsOiAnZ2VuZXJhbC9hY2NvdW50cz9hY3Rpb249Y3JlYXRlJywgbWV0aG9kOiAncG9zdCcgfSB9LFxuICAgICAgeyBuYW1lOiAnZWRpdCcsIGRpYWxvZzogdHJ1ZSwgYWN0aW9uOiB7IHVybDogJ2dlbmVyYWwvYWNjb3VudHM/YWN0aW9uPWVkaXQnLCBtZXRob2Q6ICdwb3N0JyB9IH0sXG4gICAgICB7IG5hbWU6ICdkZWxldGUnLCBkaWFsb2c6IHRydWUsIGFjdGlvbjogeyB1cmw6ICdnZW5lcmFsL2FjY291bnRzP2FjdGlvbj1kZWxldGUnLCBtZXRob2Q6ICdwb3N0JyB9IH0sXG4gICAgXSxcblxuICAgIGxvYWRBY3Rpb246IHsgdXJsOiAnZ2VuZXJhbC9hY2NvdW50cy94JyB9LFxuXG4gICAgZm9ybUNvbmZpZzogdGhpcy5mb3JtQ29uZmlnXG5cbiAgfVxuXG59XG4iLCI8aDQ+QWNjb3VudHM8L2g0PlxuPGhyPlxuXG5cbjxkaXYgY2xhc3M9XCJtdC0zXCIgc3R5bGU9XCIgZm9udC1zaXplOiAxNHB4O1wiPlxuICA8c3BhLXRhYmxlIFtjb25maWddPVwiY29uZmlnXCIgKGFjdGlvbkNsaWNrKT1cImNsaWNrZWQoJGV2ZW50KVwiIFtyZWxvYWRdPVwicmVsb2FkXCI+PC9zcGEtdGFibGU+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -140,10 +140,10 @@ export class FormComponent {
|
|
|
140
140
|
}
|
|
141
141
|
}
|
|
142
142
|
FormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FormComponent, deps: [{ token: i1.MessageService }, { token: i2.DataServiceLib }], target: i0.ɵɵFactoryTarget.Component });
|
|
143
|
-
FormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FormComponent, selector: "spa-form", inputs: { files: "files", data: "data", config: "config" }, outputs: { buttonClick: "buttonClick", inputChange: "inputChange" }, usesOnChanges: true, ngImport: i0, template: "\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\r\n\r\n <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view' ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n <ng-container *ngIf=\"!field.hidden\" >\r\n\r\n <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n <label style=\"font-size: larger;\">{{field.name | camelToWords}}</label>\r\n </div>\r\n\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n <spa-attach message=\"Drag and Drop files here\" [(files)]=\"files\"></spa-attach>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'file-view'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n <spa-viewer [fileAction]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n </div>\r\n </ng-container>\r\n\r\n\r\n <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-number>\r\n\r\n <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-money>\r\n\r\n <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-check>\r\n\r\n <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-date>\r\n\r\n <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\">\r\n </spa-select>\r\n\r\n <spa-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\" [multiple]=\"true\">\r\n </spa-select>\r\n\r\n <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionValue]=\"field.optionValue\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-text>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </div>\r\n\r\n\r\n <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n <button mat-raised-button color=\"primary\" (click)=\"buttonClicked()\" cdkFocusInitial>{{buttonDisplay}}</button>\r\n </div>\r\n\r\n\r\n</div>\r\n", styles: [".title{margin-top:1em;font-size:larger;font-weight:300}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.TextComponent, selector: "spa-text", inputs: ["readonly", "hint", "display", "placeholder", "value", "format", "type", "rows", "width", "options", "optionValue", "required", "min", "max", "regex"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i6.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value"], outputs: ["valueChange", "click", "check", "uncheck"] }, { kind: "component", type: i7.DateComponent, selector: "spa-date", inputs: ["required", "min", "max", "readonly", "hint", "value", "display", "placeholder", "width"], outputs: ["valueChange"] }, { kind: "component", type: i8.SelectComponent, selector: "spa-select", inputs: ["width", "readonly", "readonlyMode", "hint", "placeholder", "multiple", "display", "value", "options", "optionValue", "optionDisplay", "optionDisplayExtra"], outputs: ["valueChange"] }, { kind: "component", type: i9.MoneyComponent, selector: "spa-money", inputs: ["readonly", "hint", "display", "placeholder", "value", "width", "currency", "required", "min", "max"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i10.AttachComponent, selector: "spa-attach", inputs: ["message", "files", "enableUpload"], outputs: ["filesChange", "upload"] }, { kind: "component", type: i11.NumberComponent, selector: "spa-number", inputs: ["readonly", "hint", "display", "placeholder", "value", "width", "required", "min", "max", "step"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i12.ViewerComponent, selector: "spa-viewer", inputs: ["fileAction", "path", "folderName", "fileNames", "removable", "display", "title"], outputs: ["remove"] }, { kind: "pipe", type: i13.CamelToWordsPipe, name: "camelToWords" }] });
|
|
143
|
+
FormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FormComponent, selector: "spa-form", inputs: { files: "files", data: "data", config: "config" }, outputs: { buttonClick: "buttonClick", inputChange: "inputChange" }, usesOnChanges: true, ngImport: i0, template: "\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\r\n\r\n <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view' ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n <ng-container *ngIf=\"!field.hidden\" >\r\n\r\n <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n <label style=\"font-size: larger;\">{{field.name | camelToWords}}</label>\r\n </div>\r\n\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n <spa-attach message=\"Drag and Drop files here\" [(files)]=\"files\"></spa-attach>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'file-view'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n <spa-viewer [fileAction]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n </div>\r\n </ng-container>\r\n\r\n\r\n <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-number>\r\n\r\n <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-money>\r\n\r\n <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-check>\r\n\r\n <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-date>\r\n\r\n <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\">\r\n </spa-select>\r\n\r\n <spa-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\" [multiple]=\"true\">\r\n </spa-select>\r\n\r\n <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-text>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </div>\r\n\r\n\r\n <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n <button mat-raised-button color=\"primary\" (click)=\"buttonClicked()\" cdkFocusInitial>{{buttonDisplay}}</button>\r\n </div>\r\n\r\n\r\n</div>\r\n", styles: [".title{margin-top:1em;font-size:larger;font-weight:300}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.TextComponent, selector: "spa-text", inputs: ["readonly", "hint", "display", "placeholder", "value", "format", "type", "rows", "width", "options", "optionValue", "required", "min", "max", "regex"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i6.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value"], outputs: ["valueChange", "click", "check", "uncheck"] }, { kind: "component", type: i7.DateComponent, selector: "spa-date", inputs: ["required", "min", "max", "readonly", "hint", "value", "display", "placeholder", "width"], outputs: ["valueChange"] }, { kind: "component", type: i8.SelectComponent, selector: "spa-select", inputs: ["width", "readonly", "readonlyMode", "hint", "placeholder", "multiple", "display", "value", "options", "optionValue", "optionDisplay", "optionDisplayExtra"], outputs: ["valueChange"] }, { kind: "component", type: i9.MoneyComponent, selector: "spa-money", inputs: ["readonly", "hint", "display", "placeholder", "value", "width", "currency", "required", "min", "max"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i10.AttachComponent, selector: "spa-attach", inputs: ["message", "files", "enableUpload"], outputs: ["filesChange", "upload"] }, { kind: "component", type: i11.NumberComponent, selector: "spa-number", inputs: ["readonly", "hint", "display", "placeholder", "value", "width", "required", "min", "max", "step"], outputs: ["valueChange", "leave", "enterPress"] }, { kind: "component", type: i12.ViewerComponent, selector: "spa-viewer", inputs: ["fileAction", "path", "folderName", "fileNames", "removable", "display", "title"], outputs: ["remove"] }, { kind: "pipe", type: i13.CamelToWordsPipe, name: "camelToWords" }] });
|
|
144
144
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FormComponent, decorators: [{
|
|
145
145
|
type: Component,
|
|
146
|
-
args: [{ selector: 'spa-form', template: "\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\r\n\r\n <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view' ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n <ng-container *ngIf=\"!field.hidden\" >\r\n\r\n <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n <label style=\"font-size: larger;\">{{field.name | camelToWords}}</label>\r\n </div>\r\n\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n <spa-attach message=\"Drag and Drop files here\" [(files)]=\"files\"></spa-attach>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'file-view'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n <spa-viewer [fileAction]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n </div>\r\n </ng-container>\r\n\r\n\r\n <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-number>\r\n\r\n <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-money>\r\n\r\n <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-check>\r\n\r\n <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-date>\r\n\r\n <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\">\r\n </spa-select>\r\n\r\n <spa-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\" [multiple]=\"true\">\r\n </spa-select>\r\n\r\n <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionValue]=\"field.optionValue\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-text>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </div>\r\n\r\n\r\n <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n <button mat-raised-button color=\"primary\" (click)=\"buttonClicked()\" cdkFocusInitial>{{buttonDisplay}}</button>\r\n </div>\r\n\r\n\r\n</div>\r\n", styles: [".title{margin-top:1em;font-size:larger;font-weight:300}\n"] }]
|
|
146
|
+
args: [{ selector: 'spa-form', template: "\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\r\n\r\n <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view' ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n <ng-container *ngIf=\"!field.hidden\" >\r\n\r\n <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n <label style=\"font-size: larger;\">{{field.name | camelToWords}}</label>\r\n </div>\r\n\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n <spa-attach message=\"Drag and Drop files here\" [(files)]=\"files\"></spa-attach>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'file-view'\">\r\n <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n <spa-viewer [fileAction]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n </div>\r\n </ng-container>\r\n\r\n\r\n <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-number>\r\n\r\n <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-money>\r\n\r\n <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-check>\r\n\r\n <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-date>\r\n\r\n <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\">\r\n </spa-select>\r\n\r\n <spa-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\" [multiple]=\"true\">\r\n </spa-select>\r\n\r\n <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-text>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </div>\r\n\r\n\r\n <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n <button mat-raised-button color=\"primary\" (click)=\"buttonClicked()\" cdkFocusInitial>{{buttonDisplay}}</button>\r\n </div>\r\n\r\n\r\n</div>\r\n", styles: [".title{margin-top:1em;font-size:larger;font-weight:300}\n"] }]
|
|
147
147
|
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }]; }, propDecorators: { files: [{
|
|
148
148
|
type: Input
|
|
149
149
|
}], data: [{
|
|
@@ -155,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
155
155
|
}], inputChange: [{
|
|
156
156
|
type: Output
|
|
157
157
|
}] } });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/form/form.component.ts","../../../../../../projects/tin-spa/src/lib/components/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormConfig, Field, Button } from '../../classes/Classes';\nimport { Core } from '../../classes/TinCore';\nimport { MessageService } from '../../services/message.service';\nimport { DataServiceLib } from '../../services/data.service';\n\n@Component({\n  selector: 'spa-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit {\n\n  constructor(private messageService: MessageService, private dataService: DataServiceLib) { }\n\n  ngOnInit() {\n\n    console.log(\"Form init\")\n\n    if (!this.config.fields){\n      this.messageService.toast(\"Please Configure Form Fields\")\n      return;\n    }\n\n    if (!this.data) {\n      this.messageService.toast(\"Please Configure Form Data\")\n      return;\n    }\n\n    this.fields = this.config.fields;\n\n\n    if (this.config.multiColumn){\n      this.multiColumn = this.config.multiColumn\n    }else{\n      this.multiColumn = this.fields.length > 2\n    }\n\n    if (this.config?.button?.display){\n      this.buttonDisplay = this.config.button.display;\n    }\n\n    this.fileField = this.fields.find(x => x.type == 'file')\n\n    if (this.config?.button?.action && this.fileField) {\n      this.config.button.action.isFormData = true;\n\n    }\n\n    // this.fileViewField = this.fields.find(x => x.type == 'file-view')\n\n    // if (this.fileViewField && !this.fileViewField.hidden && this.config.mode != \"create\"){\n    //   this.loadFiles();\n    // }\n\n\n    // this.getVisibleFields();\n\n  }\n\n  // loadFiles(){\n\n  //  this.fileNames = \"TinasheXXX.pdf\"\n  //   // this.fileViewField.\n  // }\n\n  ngOnChanges() {\n    console.log(\"changed\")\n  }\n\n  ngAfterViewInit() {\n    // console.log(\"Form After View init\")\n  }\n\n  getVisibleFields(){\n    let visibleFields = this.fields.filter(x => !x.hidden)\n\n    return visibleFields\n  }\n\n\n  fileNames\n  fileField: Field;\n  fileViewField: Field;\n  @Input() files: any[] = [];\n  fields: Field[];\n  buttonDisplay = \"Submit\";\n  isProcessing : boolean = false;\n  multiColumn : boolean = false;\n\n  @Input() data: any;\n  @Input() config: FormConfig;\n  @Output() buttonClick = new EventEmitter();\n  @Output() inputChange = new EventEmitter();\n\n  inputChanged(field : Field, value){\n    this.inputChange.emit({ field: field, value: value})\n  }\n\n  buttonClicked(){\n\n    // console.log(\"Button Clicked\")\n    this.buttonClick.emit(this.data);\n    // console.log(this.data)\n\n\n\n    let button = this.config.button;\n\n    if (!button) {\n      return;\n    }\n\n    //validation\n    let resp = Core.validateObject(this.fields,this.data);\n    if (resp != ''){\n      this.messageService.toast(resp)\n      return;\n    }\n\n\n\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\n      this.messageService.toast(\"Please attach file(s)\");\n      return;\n    }\n\n\n    if (button.confirm){\n\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\n        if (result == \"yes\") {\n          this.processCall(button)\n        }\n      });\n\n    }else{\n      this.processCall(button)\n    }\n\n\n\n\n  }\n\n  processCall(button: Button){\n\n    if (!button.action) return\n\n    let dataOut;\n\n    if (button.action.isFormData){\n\n      let formData: FormData = new FormData();\n      for (let i = 0; i < this.files.length; i++) {\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\n      }\n\n      formData.append(\"data\", JSON.stringify(this.data));\n\n\n      dataOut = formData\n    }else{\n\n      dataOut = this.data\n    }\n\n\n\n\n\n\n    this.isProcessing = true\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\n      this.isProcessing = false\n\n      if (apiResponse.success) {\n\n        if (button.action.successMessage) {\n          this.messageService.toast(button.action.successMessage);\n        } else {\n          this.messageService.toast(\"Submitted\");\n        }\n\n        if (this.config.reset) {\n          Core.resetObject(this.fields, this.data)\n          this.files = [];\n        }\n\n\n      } else {\n        this.messageService.toast(\"Error: \" + apiResponse.message);\n      }\n    });\n  }\n\n  processForm(){\n\n\n\n\n\n  }\n\n}\n\n\n","\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\r\n\r\n  <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view'  ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n    <ng-container *ngIf=\"!field.hidden\" >\r\n\r\n      <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n        <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n          <label style=\"font-size: larger;\">{{field.name | camelToWords}}</label>\r\n        </div>\r\n\r\n        <ng-container *ngSwitchCase=\"'file'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n            <spa-attach message=\"Drag and Drop files here\" [(files)]=\"files\"></spa-attach>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngSwitchCase=\"'file-view'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n            <spa-viewer [fileAction]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-money>\r\n\r\n        <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-date>\r\n\r\n        <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\">\r\n        </spa-select>\r\n\r\n        <spa-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"field.readonly || config.mode =='view'\" [multiple]=\"true\">\r\n        </spa-select>\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionValue]=\"field.optionValue\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"field.readonly || config.mode =='view'\"></spa-text>\r\n\r\n      </ng-container>\r\n\r\n    </ng-container>\r\n\r\n  </div>\r\n\r\n\r\n  <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n    <button mat-raised-button color=\"primary\"  (click)=\"buttonClicked()\"  cdkFocusInitial>{{buttonDisplay}}</button>\r\n  </div>\r\n\r\n\r\n</div>\r\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/form/form.component.ts","../../../../../../projects/tin-spa/src/lib/components/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormConfig, Field, Button } from '../../classes/Classes';\nimport { Core } from '../../classes/TinCore';\nimport { MessageService } from '../../services/message.service';\nimport { DataServiceLib } from '../../services/data.service';\n\n@Component({\n  selector: 'spa-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit {\n\n  constructor(private messageService: MessageService, private dataService: DataServiceLib) { }\n\n  ngOnInit() {\n\n    console.log(\"Form init\")\n\n    if (!this.config.fields){\n      this.messageService.toast(\"Please Configure Form Fields\")\n      return;\n    }\n\n    if (!this.data) {\n      this.messageService.toast(\"Please Configure Form Data\")\n      return;\n    }\n\n    this.fields = this.config.fields;\n\n\n    if (this.config.multiColumn){\n      this.multiColumn = this.config.multiColumn\n    }else{\n      this.multiColumn = this.fields.length > 2\n    }\n\n    if (this.config?.button?.display){\n      this.buttonDisplay = this.config.button.display;\n    }\n\n    this.fileField = this.fields.find(x => x.type == 'file')\n\n    if (this.config?.button?.action && this.fileField) {\n      this.config.button.action.isFormData = true;\n\n    }\n\n    // this.fileViewField = this.fields.find(x => x.type == 'file-view')\n\n    // if (this.fileViewField && !this.fileViewField.hidden && this.config.mode != \"create\"){\n    //   this.loadFiles();\n    // }\n\n\n    // this.getVisibleFields();\n\n  }\n\n  // loadFiles(){\n\n  //  this.fileNames = \"TinasheXXX.pdf\"\n  //   // this.fileViewField.\n  // }\n\n  ngOnChanges() {\n    console.log(\"changed\")\n  }\n\n  ngAfterViewInit() {\n    // console.log(\"Form After View init\")\n  }\n\n  getVisibleFields(){\n    let visibleFields = this.fields.filter(x => !x.hidden)\n\n    return visibleFields\n  }\n\n\n  fileNames\n  fileField: Field;\n  fileViewField: Field;\n  @Input() files: any[] = [];\n  fields: Field[];\n  buttonDisplay = \"Submit\";\n  isProcessing : boolean = false;\n  multiColumn : boolean = false;\n\n  @Input() data: any;\n  @Input() config: FormConfig;\n  @Output() buttonClick = new EventEmitter();\n  @Output() inputChange = new EventEmitter();\n\n  inputChanged(field : Field, value){\n    this.inputChange.emit({ field: field, value: value})\n  }\n\n  buttonClicked(){\n\n    // console.log(\"Button Clicked\")\n    this.buttonClick.emit(this.data);\n    // console.log(this.data)\n\n\n\n    let button = this.config.button;\n\n    if (!button) {\n      return;\n    }\n\n    //validation\n    let resp = Core.validateObject(this.fields,this.data);\n    if (resp != ''){\n      this.messageService.toast(resp)\n      return;\n    }\n\n\n\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\n      this.messageService.toast(\"Please attach file(s)\");\n      return;\n    }\n\n\n    if (button.confirm){\n\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\n        if (result == \"yes\") {\n          this.processCall(button)\n        }\n      });\n\n    }else{\n      this.processCall(button)\n    }\n\n\n\n\n  }\n\n  processCall(button: Button){\n\n    if (!button.action) return\n\n    let dataOut;\n\n    if (button.action.isFormData){\n\n      let formData: FormData = new FormData();\n      for (let i = 0; i < this.files.length; i++) {\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\n      }\n\n      formData.append(\"data\", JSON.stringify(this.data));\n\n\n      dataOut = formData\n    }else{\n\n      dataOut = this.data\n    }\n\n\n\n\n\n\n    this.isProcessing = true\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\n      this.isProcessing = false\n\n      if (apiResponse.success) {\n\n        if (button.action.successMessage) {\n          this.messageService.toast(button.action.successMessage);\n        } else {\n          this.messageService.toast(\"Submitted\");\n        }\n\n        if (this.config.reset) {\n          Core.resetObject(this.fields, this.data)\n          this.files = [];\n        }\n\n\n      } else {\n        this.messageService.toast(\"Error: \" + apiResponse.message);\n      }\n    });\n  }\n\n  processForm(){\n\n\n\n\n\n  }\n\n}\n\n\n","\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\r\n\r\n  <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view'  ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n    <ng-container *ngIf=\"!field.hidden\" >\r\n\r\n      <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n        <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n          <label style=\"font-size: larger;\">{{field.name | camelToWords}}</label>\r\n        </div>\r\n\r\n        <ng-container *ngSwitchCase=\"'file'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n            <spa-attach message=\"Drag and Drop files here\" [(files)]=\"files\"></spa-attach>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngSwitchCase=\"'file-view'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n            <spa-viewer [fileAction]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit')  || config.mode =='view'\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-money>\r\n\r\n        <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-date>\r\n\r\n        <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\">\r\n        </spa-select>\r\n\r\n        <spa-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\" [multiple]=\"true\">\r\n        </spa-select>\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"(field.readonly && config.mode =='edit') || config.mode =='view'\"></spa-text>\r\n\r\n      </ng-container>\r\n\r\n    </ng-container>\r\n\r\n  </div>\r\n\r\n\r\n  <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n    <button mat-raised-button color=\"primary\"  (click)=\"buttonClicked()\"  cdkFocusInitial>{{buttonDisplay}}</button>\r\n  </div>\r\n\r\n\r\n</div>\r\n"]}
|
|
@@ -72,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
72
72
|
type: Component,
|
|
73
73
|
args: [{ selector: 'spa-inventory', template: "<h4>Inventory</h4>\n<hr>\n\n\n<div class=\"mt-3\" style=\" font-size: 14px;\">\n <spa-table [config]=\"config\" (actionClick)=\"clicked($event)\" [reload]=\"reload\"></spa-table>\n</div>\n" }]
|
|
74
74
|
}], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }, { type: i3.AuthService }, { type: i4.MatDialog }]; } });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52ZW50b3J5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL2ludmVudG9yeS9pbnZlbnRvcnkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvaW52ZW50b3J5L2ludmVudG9yeS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBS2xELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUU1RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7Ozs7O0FBUS9CLE1BQU0sT0FBTyxrQkFBa0I7SUFFN0IsWUFBb0IsV0FBMkIsRUFBVSxjQUE4QixFQUFTLFdBQXdCLEVBQVMsTUFBaUI7UUFBOUgsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBQVUsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQVMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFXO1FBS2xKLFdBQU0sR0FBcUIsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQXlCekMsZUFBVSxHQUFlO1lBRXZCLE1BQU0sRUFBRTtnQkFDTixFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRTtnQkFDOUIsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUU7Z0JBQ3JDLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRyxJQUFJLEVBQUU7Z0JBQy9DLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxHQUFHO2dCQUNqQyxFQUFFLElBQUks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LHFEQ2YvQiwrTEFPQTsyRkRRYSxrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYXRhU2VydmljZUxpYiB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2RhdGEuc2VydmljZSc7XG5pbXBvcnQgeyBGb3JtQ29uZmlnLCBUYWJsZUNvbmZpZyB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XG5pbXBvcnQgeyBNZXNzYWdlU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL21lc3NhZ2Uuc2VydmljZSc7XG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2F1dGguc2VydmljZSc7XG5pbXBvcnQgeyBxdWFudGl0eURpYWxvZyB9IGZyb20gJy4vcXVhbnRpdHlEaWFsb2cuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdERpYWxvZyB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc3BhLWludmVudG9yeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbnZlbnRvcnkuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9pbnZlbnRvcnkuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEludmVudG9yeUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkYXRhU2VydmljZTogRGF0YVNlcnZpY2VMaWIsIHByaXZhdGUgbWVzc2FnZVNlcnZpY2U6IE1lc3NhZ2VTZXJ2aWNlLCBwdWJsaWMgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlLCBwdWJsaWMgZGlhbG9nOiBNYXREaWFsb2cpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgcmVsb2FkOiBTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IFN1YmplY3QoKTtcblxuICBjbGlja2VkKHgpe1xuXG4gICAgaWYgKHgubmFtZSA9PSBcImluY3JlYXNlXCIgfHwgeC5uYW1lID09IFwiZGVjcmVhc2VcIil7XG4gICAgICB0aGlzLmNvbW1lbnQoeClcbiAgICB9XG4gIH1cblxuICBjb21tZW50KHgpIHtcblxuICAgIGNvbnN0IGRpYWxvZ1JlZiA9IHRoaXMuZGlhbG9nLm9wZW4ocXVhbnRpdHlEaWFsb2csIHtcbiAgICAgIHdpZHRoOiBcIjkwMHB4XCIsXG4gICAgICBkYXRhOiB4LFxuICAgIH0pO1xuXG4gICAgZGlhbG9nUmVmLmFmdGVyQ2xvc2VkKCkuc3Vic2NyaWJlKChyZXN1bHQpID0+IHtcblxuICAgICAgaWYgKHJlc3VsdCA9PSAnc3VjY2VzcycpIHtcbiAgICAgICAgdGhpcy5yZWxvYWQubmV4dCh0cnVlKTtcbiAgICAgICAgdGhpcy5tZXNzYWdlU2VydmljZS50b2FzdChcIlVwZGF0ZWRcIilcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIGZvcm1Db25maWc6IEZvcm1Db25maWcgPSB7XG5cbiAgICBmaWVsZHM6IFtcbiAgICAgIHsgbmFtZTogJ25hbWUnLCB0eXBlOiAndGV4dCcgfSxcbiAgICAgIHsgbmFtZTogJ2Rlc2NyaXB0aW9uJywgdHlwZTogJ3RleHQnIH0sXG4gICAgICB7IG5hbWU6ICdzZXJpYWwnLCB0eXBlOiAndGV4dCcsIGhpZGRlbiA6IHRydWUgfSxcbiAgICAgIHsgbmFtZTogJ3ByaWNlJywgdHlwZTogJ21vbmV5JywgfSxcbiAgICAgIHsgbmFtZTogJ21pblF1YW50aXR5JywgYWxpYXMgOiAnTWluaW11bSBRdWFudGl0eScsIHR5cGU6ICdudW1iZXInIH0sXG5cbiAgICAgIC8vIHsgbmFtZTogJ3Npbmd1bGFyJywgdHlwZTogJ2NoZWNrYm94JywgfSxcblxuICAgIF0sXG5cbiAgICByZXNldDogdHJ1ZSxcbiAgfVxuXG4gIGNvbmZpZzogVGFibGVDb25maWcgPSB7XG4gICAgc2hvd0ZpbHRlcjogdHJ1ZSxcbiAgICBtaW5Db2x1bW5zOiBbJ25hbWUnXSxcbiAgICBsb2dSZXNwb25zZTogdHJ1ZSxcblxuICAgIGNvbHVtbnM6IFtcbiAgICAgIHsgbmFtZTogJ25hbWUnLCB0eXBlOiAndGV4dCcgfSxcbiAgICAgIHsgbmFtZTogJ2Rlc2NyaXB0aW9uJywgdHlwZTogJ3RleHQnIH0sXG4gICAgICB7IG5hbWU6ICdxdWFudGl0eScsIHR5cGU6ICdudW1iZXInLCBpY29uIDp7bmFtZSA6ICd3YXJuaW5nJywgY29sb3IgOiAncmVkJywgdGlwIDogJ1N0b2NrIHVwJywgY29uZGl0aW9uIDogeCA9PiB4LnF1YW50aXR5IDw9IHgubWluUXVhbnRpdHl9IH0sXG4gICAgICB7IG5hbWU6ICdwcmljZScsIHR5cGU6ICdtb25leScsIH0sXG4gICAgXSxcblxuICAgIGJ1dHRvbnM6IFtcbiAgICAgIHsgbmFtZTogJ2luY3JlYXNlJywgaWNvbjogeyBuYW1lOiAnYWRkJyB9LCBjb2xvcjogJ2dyZWVuJywgfSwgLy9hY3Rpb246IHsgdXJsOiAnZ2VuZXJhbC9pbnZlbnRvcnk/YWN0aW9uPWluY3JlYXNlJywgbWV0aG9kOiAncG9zdCcgfVxuICAgICAgeyBuYW1lOiAnZGVjcmVhc2UnLCBpY29uOiB7IG5hbWU6ICdyZW1vdmUnIH0sIGNvbG9yOiAncmVkJywgIH0sXG4gICAgICB7IG5hbWU6ICdjcmVhdGUnLCBkaXNwbGF5OiAnQ3JlYXRlJywgZGlhbG9nOiB0cnVlLCBhY3Rpb246IHsgdXJsOiAnZ2VuZXJhbC9pbnZlbnRvcnk/YWN0aW9uPWNyZWF0ZScsIG1ldGhvZDogJ3Bvc3QnIH0gfSxcblxuICAgICAgeyBuYW1lOiAnZWRpdCcsIGRpYWxvZzogdHJ1ZSwgYWN0aW9uOiB7IHVybDogJ2dlbmVyYWwvaW52ZW50b3J5P2FjdGlvbj1lZGl0JywgbWV0aG9kOiAncG9zdCcgfSB9LFxuICAgICAgeyBuYW1lOiAnZGVsZXRlJywgZGlhbG9nOiB0cnVlLCBhY3Rpb246IHsgdXJsOiAnZ2VuZXJhbC9pbnZlbnRvcnk/YWN0aW9uPWRlbGV0ZScsIG1ldGhvZDogJ3Bvc3QnIH0gfSxcbiAgICBdLFxuXG4gICAgbG9hZEFjdGlvbjogeyB1cmw6ICdnZW5lcmFsL2ludmVudG9yeS94JyB9LFxuXG4gICAgZm9ybUNvbmZpZzogdGhpcy5mb3JtQ29uZmlnXG5cbiAgfVxuXG5cbn1cbiIsIjxoND5JbnZlbnRvcnk8L2g0PlxuPGhyPlxuXG5cbjxkaXYgY2xhc3M9XCJtdC0zXCIgc3R5bGU9XCIgZm9udC1zaXplOiAxNHB4O1wiPlxuICA8c3BhLXRhYmxlIFtjb25maWddPVwiY29uZmlnXCIgKGFjdGlvbkNsaWNrKT1cImNsaWNrZWQoJGV2ZW50KVwiIFtyZWxvYWRdPVwicmVsb2FkXCI+PC9zcGEtdGFibGU+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -39,16 +39,16 @@ export class LoginComponent {
|
|
|
39
39
|
}
|
|
40
40
|
ngOnInit() {
|
|
41
41
|
this.dataService.appConfigObserv.subscribe(x => this.appConfig = x);
|
|
42
|
-
this.authService.autoLoginObserv.subscribe(x => {
|
|
43
|
-
this.autoLogin = x;
|
|
44
|
-
console.log("AUTO LOGIN :" + this.autoLogin);
|
|
45
|
-
});
|
|
46
42
|
if (this.route.snapshot.queryParams["redirectTo"] != undefined) {
|
|
47
43
|
this.redirectPath = this.route.snapshot.queryParams["redirectTo"];
|
|
48
44
|
}
|
|
49
45
|
else {
|
|
50
46
|
this.redirectPath = "home";
|
|
51
47
|
}
|
|
48
|
+
this.authService.autoLoginObserv.subscribe(x => {
|
|
49
|
+
this.autoLogin = x;
|
|
50
|
+
console.log("AUTO LOGIN :" + this.autoLogin);
|
|
51
|
+
});
|
|
52
52
|
this.socialUser = null;
|
|
53
53
|
this.socialService.authState.subscribe((socialUser) => {
|
|
54
54
|
this.socialUser = socialUser;
|
|
@@ -58,6 +58,7 @@ export class LoginComponent {
|
|
|
58
58
|
this.user.authType = socialUser.provider;
|
|
59
59
|
this.login();
|
|
60
60
|
});
|
|
61
|
+
// this.authService.logoff();
|
|
61
62
|
}
|
|
62
63
|
signup() {
|
|
63
64
|
this.router.navigate(["signup"]);
|
|
@@ -124,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
124
125
|
type: Component,
|
|
125
126
|
args: [{ selector: "spa-login", template: "\r\n <div *ngIf=\"style=='old'\" class=\"tin-bg-login login-page\">\r\n\r\n <div *ngIf=\"appConfig.logo!=''\" class=\"d-flex justify-content-center row align-items-center\" style=\"margin-top:3em;margin-bottom:1em\">\r\n\r\n <img *ngIf=\"appConfig.logoSize=='normal'\" [src]=\"appConfig.logo\" style=\"width: 100px;margin-right:3em;margin-left:3em\" />\r\n <img *ngIf=\"appConfig.logoSize=='medium'\" [src]=\"appConfig.logo\" style=\"width: 150px;margin-right:3em;margin-left:3em\" />\r\n <img *ngIf=\"appConfig.logoSize=='large'\" [src]=\"appConfig.logo\" style=\"width: 250px; margin-right:3em;margin-left:3em\" />\r\n\r\n </div>\r\n\r\n\r\n <div *ngIf=\"appConfig.logo ==''\" style=\"margin-top:2em\">\r\n <!-- Add margin top when there is no logo -->\r\n </div>\r\n\r\n\r\n <div class=\"d-flex justify-content-center row align-items-center\" style=\"margin-top:3em;\">\r\n\r\n <div class=\"d-none d-sm-block\">\r\n </div>\r\n\r\n <div style=\"margin-left:1em\">\r\n\r\n <mat-card class=\"mat-elevation-z3 login-card\" style=\"width:400px; \">\r\n\r\n <mat-card-header>\r\n <mat-card-title>{{appConfig.appName}}</mat-card-title>\r\n </mat-card-header>\r\n\r\n <mat-card-content>\r\n\r\n <div class=\"tin-input mt-2\">\r\n\r\n <spa-text id=\"txtuserName\" display=\"Username\" [(value)]=\"user.userName\" ></spa-text>\r\n\r\n <mat-form-field >\r\n <mat-label>Password</mat-label>\r\n <input id=\"txtPassword\" matInput [type]=\"hide ? 'password' : 'text'\" (keyup.enter)=\"login()\" [(ngModel)]=\"user.password\" autocomplete=\"off\" >\r\n <button mat-icon-button matSuffix (click)=\"hide = !hide\" [attr.aria-label]=\"'Hide password'\" [attr.aria-pressed]=\"hide\">\r\n <mat-icon style=\"font-size: 18px;\">{{hide ? 'visibility_off' : 'visibility'}}</mat-icon>\r\n </button>\r\n </mat-form-field>\r\n\r\n </div>\r\n\r\n </mat-card-content>\r\n\r\n\r\n <mat-card-actions>\r\n\r\n <div class=\"row \">\r\n\r\n <div class=\"col d-flex justify-content-center\">\r\n <button id=\"btnLogin\" mat-raised-button [disabled]=\"isProcessing\" style=\"width: 100px;\" (click)=\"login()\" color=\"primary\">Login</button>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-center\" *ngIf=\"appConfig.selfService\">\r\n <button id=\"btnSignup\" mat-stroked-button color=\"primary\" style=\"width: 100px;\" (click)=\"signup()\">Signup</button>\r\n </div>\r\n\r\n </div>\r\n\r\n </mat-card-actions>\r\n\r\n </mat-card>\r\n\r\n <div *ngIf=\"appConfig.selfService\">\r\n <br />\r\n <a mat-button id=\"lnkRecover\" style=\"margin-left: 1em\" (click)=\"recoverAccount()\">Forgot your password ?</a>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n <div *ngIf=\"style=='default'\" class=\"login-page background tin-bg-login\">\r\n\r\n <div class=\"container\" >\r\n\r\n <div class=\"logo\">\r\n <img *ngIf=\"appConfig.logoSize=='normal'\" [src]=\"appConfig.logo\" style=\"width: 100px\" />\r\n <img *ngIf=\"appConfig.logoSize=='medium'\" [src]=\"appConfig.logo\" style=\"width: 150px\" />\r\n <img *ngIf=\"appConfig.logoSize=='large'\" [src]=\"appConfig.logo\" style=\"width: 250px\" />\r\n </div>\r\n\r\n <mat-card class=\"mat-elevation-z3 \" style=\"width:400px; \">\r\n\r\n <mat-card-header>\r\n <mat-card-title style=\"font-size: 40px;margin-bottom: 0px; font-weight: 300\">{{appConfig.appName}}</mat-card-title>\r\n </mat-card-header>\r\n\r\n <mat-card-content>\r\n\r\n <div class=\"tin-input mt-2\">\r\n\r\n <spa-text id=\"txtuserName\" display=\"Username\" [(value)]=\"user.userName\"></spa-text>\r\n\r\n <spa-text id=\"txtPassword\" display=\"Password\" format=\"password\" [(value)]=\"user.password\" (enterPress)=\"login()\"></spa-text>\r\n\r\n </div>\r\n\r\n </mat-card-content>\r\n\r\n\r\n <mat-card-actions style=\"margin-bottom: 10px;\">\r\n\r\n <div class=\"button mt-0\">\r\n <button id=\"btnLogin\" mat-flat-button [disabled]=\"isProcessing\" style=\"width: 300px;\" (click)=\"login()\" color=\"primary\">Login</button>\r\n </div>\r\n\r\n <div class=\"button\" *ngIf=\"appConfig.selfService\" >\r\n <button id=\"btnSignup\" mat-stroked-button color=\"primary\" style=\"width: 300px;\" (click)=\"signup()\">Sign up with Email</button>\r\n </div>\r\n\r\n <div class=\"button\" *ngIf=\"appConfig.selfService\">\r\n <asl-google-signin-button type='standard' width=\"300px\" size='medium' logo_alignment=\"center\" style=\"text-align: center;\"></asl-google-signin-button>\r\n </div>\r\n\r\n\r\n\r\n\r\n\r\n </mat-card-actions>\r\n\r\n </mat-card>\r\n\r\n <a *ngIf=\"appConfig.selfService\" mat-button id=\"lnkRecover\" style=\"margin-top: 1em\" (click)=\"recoverAccount()\">Forgot your password ?</a>\r\n\r\n\r\n\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"style=='bs'\">\r\n\r\n <div class=\"container\">\r\n\r\n <div class=\"image\">\r\n <img class=\"mb-4\" src=\"c:\\Tinashe\\Code\\Angular\\Junk\\bs-examples\\assets\\brand\\bootstrap-logo.svg\" alt=\"\" width=\"72\" height=\"57\">\r\n </div>\r\n\r\n <div class=\"details\">\r\n <h1 class=\"h3 mb-3 fw-normal\" >Please sign in</h1>\r\n\r\n <div class=\"form-floating\">\r\n <input class=\"form-control\" id=\"floatingInput\" placeholder=\"name@example.com\" [(ngModel)]=\"user.userName\">\r\n <label for=\"floatingInput\">Username</label>\r\n </div>\r\n\r\n <div class=\"form-floating\">\r\n <input type=\"password\" class=\"form-control\" id=\"floatingPassword\" placeholder=\"Password\" [(ngModel)]=\"user.password\">\r\n <label for=\"floatingPassword\">Password</label>\r\n </div>\r\n\r\n <div class=\"form-check text-start my-3\">\r\n <input class=\"form-check-input\" type=\"checkbox\" value=\"remember-me\" id=\"flexCheckDefault\" >\r\n <label class=\"form-check-label\" for=\"flexCheckDefault\">\r\n Remember me\r\n </label>\r\n </div>\r\n\r\n <button class=\"btn btn-primary w-100 py-2\" (click)=\"login()\">Sign in</button>\r\n\r\n </div>\r\n\r\n <p class=\"mt-5 mb-3 text-body-secondary\">© 2017\u20132023</p>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n", styles: [".login-page{position:absolute;inset:0;overflow:auto}.background{min-height:100%}.container{display:flex;flex-direction:column;align-items:center;height:100vh}.logo{margin-top:3em;margin-bottom:1em}.buttons{display:flex;flex-direction:row;justify-content:space-evenly}.button{display:flex;flex-direction:row;justify-content:center;margin-top:10px}\n"] }]
|
|
126
127
|
}], ctorParameters: function () { return [{ type: i1.HttpService }, { type: i2.StorageService }, { type: i3.Router }, { type: i4.MessageService }, { type: i5.DataServiceLib }, { type: i6.AuthService }, { type: i7.LogService }, { type: i3.ActivatedRoute }, { type: i8.SocialAuthService }]; } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/login/login.component.ts","../../../../../../projects/tin-spa/src/lib/components/login/login.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MessageService } from \"../../services/message.service\";\r\nimport { StorageService } from \"../../services/storage.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { Component, OnInit, Input } from \"@angular/core\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { DataServiceLib } from \"../../services/data.service\";\r\nimport { LogService } from \"./../../services/log.service\";\r\nimport { User, AppConfig } from \"../../classes/Classes\";\r\nimport { HttpService } from \"../../services/http.service\";\r\nimport { ApiResponse, Constants } from \"../../classes/TinCore\";\r\nimport { SocialAuthService, SocialUser } from '@abacritt/angularx-social-login';\r\n\r\n@Component({\r\n  selector: \"spa-login\",\r\n  templateUrl: \"./login.component.html\",\r\n  styleUrls: [\"./login.component.css\"],\r\n})\r\nexport class LoginComponent implements OnInit {\r\n\r\n  constructor(private httpService: HttpService, private storageService: StorageService, public router: Router, private messageService: MessageService, public dataService: DataServiceLib,\r\n    public authService: AuthService, private logService: LogService, private route: ActivatedRoute, private socialService: SocialAuthService  ) { }\r\n\r\n  ngOnInit() {\r\n\r\n    this.dataService.appConfigObserv.subscribe(x => this.appConfig = x);\r\n\r\n\r\n    this.authService.autoLoginObserv.subscribe(x => {\r\n      this.autoLogin = x\r\n      console.log(\"AUTO LOGIN :\" + this.autoLogin)\r\n    })\r\n\r\n\r\n    if (this.route.snapshot.queryParams[\"redirectTo\"] != undefined) {\r\n      this.redirectPath = this.route.snapshot.queryParams[\"redirectTo\"]\r\n    }else{\r\n      this.redirectPath = \"home\"\r\n    }\r\n\r\n    this.socialUser = null;\r\n\r\n    this.socialService.authState.subscribe((socialUser: SocialUser) => {\r\n\r\n      this.socialUser = socialUser;\r\n\r\n      this.user.userName = socialUser.id;\r\n      this.user.password = \"x\"\r\n      this.user.token = socialUser.idToken;\r\n      this.user.authType = socialUser.provider;\r\n\r\n      this.login();\r\n\r\n    });\r\n\r\n  }\r\n\r\n  autoLogin: boolean;\r\n  socialUser: SocialUser | null;\r\n\r\n  style: string = \"default\";\r\n\r\n  email: string = \"\";\r\n  password: string = \"\";\r\n\r\n  redirectPath\r\n\r\n  public user = new User();\r\n  hide = true;\r\n  isProcessing: boolean = false;\r\n\r\n  appConfig = new AppConfig();\r\n\r\n  public signup() {\r\n    this.router.navigate([\"signup\"]);\r\n  }\r\n\r\n  public recoverAccount() {\r\n    this.router.navigate([\"recover-account\"]);\r\n  }\r\n\r\n  public login() {\r\n\r\n\r\n    if (this.user.userName == \"\" || this.user.password == \"\") {\r\n      this.messageService.toast(\"Please enter your credentials\");\r\n      return;\r\n    }\r\n\r\n\r\n    this.logService.info(\"logging in\");\r\n\r\n    this.isProcessing = true;\r\n\r\n\r\n    this.user.userName = this.user.userName\r\n\r\n    this.dataService.Login(this.user).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      this.isProcessing = false;\r\n\r\n\r\n      if (apiResponse.success) {\r\n\r\n        // if (apiResponse.data.authType == 'local' && !this.appConfig.localAuth) {\r\n        //   this.messageService.toast(\"Contact Admin: Authentication Type error\");\r\n        //   return;\r\n        // }\r\n\r\n        // if (apiResponse.data.authType == 'AD' && !this.appConfig.ADAuth) {\r\n        //   this.messageService.toast(\"Contact Admin: Authentication Type error\");\r\n        //   return;\r\n        // }\r\n\r\n\r\n        this.authService.Updateloggedin(true);\r\n\r\n        this.authService.UpdateToken(apiResponse.data.token);\r\n        this.storageService.store(Constants.AUTH_TOKEN, apiResponse.data.token);\r\n\r\n        this.authService.UpdateTokenExpire(apiResponse.data.expiration);\r\n        this.storageService.store(Constants.AUTH_TOKEN_EXPIRE, apiResponse.data.expiration);\r\n\r\n        this.authService.UpdateCurrentUser(this.user.userName);\r\n        this.storageService.store(Constants.AUTH_USER, this.user.userName);\r\n\r\n        this.authService.updateLoggedUserFullName(apiResponse.data.firstName);\r\n        this.storageService.store(Constants.AUTH_NAME, apiResponse.data.firstName);\r\n\r\n        this.authService.UpdateRole(apiResponse.data.role);\r\n        this.storageService.store(Constants.AUTH_ROLES, JSON.stringify(apiResponse.data.role));\r\n\r\n        this.authService.updateTenantName(apiResponse.data.tenantName);\r\n        this.storageService.store(Constants.AUTH_TENANT_NAME, apiResponse.data.tenantName);\r\n\r\n\r\n        this.logService.info(\"logged in\");\r\n\r\n\r\n        if (apiResponse.data.changePassword == true && apiResponse.data.authType == 'local') {\r\n\r\n          this.router.navigate([\"home/user/change-password\"], {\r\n            queryParams: { redirectTo: this.redirectPath },\r\n            queryParamsHandling: 'merge',\r\n            skipLocationChange: false\r\n          });\r\n          return\r\n        }\r\n\r\n        this.router.navigate([this.redirectPath]);\r\n\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        this.user.password = \"\";\r\n      }\r\n    },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n}\r\n","\r\n  <div *ngIf=\"style=='old'\" class=\"tin-bg-login login-page\">\r\n\r\n    <div *ngIf=\"appConfig.logo!=''\" class=\"d-flex justify-content-center row align-items-center\" style=\"margin-top:3em;margin-bottom:1em\">\r\n\r\n      <img *ngIf=\"appConfig.logoSize=='normal'\"  [src]=\"appConfig.logo\" style=\"width: 100px;margin-right:3em;margin-left:3em\" />\r\n      <img *ngIf=\"appConfig.logoSize=='medium'\"  [src]=\"appConfig.logo\" style=\"width: 150px;margin-right:3em;margin-left:3em\" />\r\n      <img *ngIf=\"appConfig.logoSize=='large'\"  [src]=\"appConfig.logo\" style=\"width: 250px; margin-right:3em;margin-left:3em\" />\r\n\r\n    </div>\r\n\r\n\r\n    <div *ngIf=\"appConfig.logo ==''\" style=\"margin-top:2em\">\r\n        <!-- Add margin top when there is no logo -->\r\n    </div>\r\n\r\n\r\n    <div class=\"d-flex justify-content-center row align-items-center\" style=\"margin-top:3em;\">\r\n\r\n      <div class=\"d-none d-sm-block\">\r\n      </div>\r\n\r\n      <div style=\"margin-left:1em\">\r\n\r\n        <mat-card class=\"mat-elevation-z3 login-card\" style=\"width:400px; \">\r\n\r\n          <mat-card-header>\r\n            <mat-card-title>{{appConfig.appName}}</mat-card-title>\r\n          </mat-card-header>\r\n\r\n          <mat-card-content>\r\n\r\n            <div class=\"tin-input mt-2\">\r\n\r\n              <spa-text id=\"txtuserName\" display=\"Username\" [(value)]=\"user.userName\" ></spa-text>\r\n\r\n              <mat-form-field >\r\n                <mat-label>Password</mat-label>\r\n                <input id=\"txtPassword\" matInput [type]=\"hide ? 'password' : 'text'\"  (keyup.enter)=\"login()\" [(ngModel)]=\"user.password\" autocomplete=\"off\" >\r\n                <button mat-icon-button matSuffix (click)=\"hide = !hide\" [attr.aria-label]=\"'Hide password'\" [attr.aria-pressed]=\"hide\">\r\n                  <mat-icon style=\"font-size: 18px;\">{{hide ? 'visibility_off' : 'visibility'}}</mat-icon>\r\n                </button>\r\n              </mat-form-field>\r\n\r\n            </div>\r\n\r\n          </mat-card-content>\r\n\r\n\r\n          <mat-card-actions>\r\n\r\n            <div class=\"row \">\r\n\r\n              <div class=\"col d-flex justify-content-center\">\r\n                <button id=\"btnLogin\"  mat-raised-button [disabled]=\"isProcessing\" style=\"width: 100px;\" (click)=\"login()\" color=\"primary\">Login</button>\r\n              </div>\r\n\r\n              <div class=\"col d-flex justify-content-center\" *ngIf=\"appConfig.selfService\">\r\n                <button id=\"btnSignup\" mat-stroked-button  color=\"primary\" style=\"width: 100px;\" (click)=\"signup()\">Signup</button>\r\n              </div>\r\n\r\n            </div>\r\n\r\n          </mat-card-actions>\r\n\r\n        </mat-card>\r\n\r\n        <div *ngIf=\"appConfig.selfService\">\r\n          <br />\r\n          <a mat-button id=\"lnkRecover\"  style=\"margin-left: 1em\" (click)=\"recoverAccount()\">Forgot your password ?</a>\r\n        </div>\r\n\r\n      </div>\r\n\r\n    </div>\r\n\r\n  </div>\r\n\r\n\r\n  <div *ngIf=\"style=='default'\" class=\"login-page background tin-bg-login\">\r\n\r\n    <div class=\"container\" >\r\n\r\n      <div class=\"logo\">\r\n        <img *ngIf=\"appConfig.logoSize=='normal'\"  [src]=\"appConfig.logo\" style=\"width: 100px\" />\r\n        <img *ngIf=\"appConfig.logoSize=='medium'\"  [src]=\"appConfig.logo\" style=\"width: 150px\" />\r\n        <img *ngIf=\"appConfig.logoSize=='large'\"  [src]=\"appConfig.logo\" style=\"width: 250px\" />\r\n      </div>\r\n\r\n      <mat-card class=\"mat-elevation-z3 \" style=\"width:400px; \">\r\n\r\n        <mat-card-header>\r\n          <mat-card-title style=\"font-size: 40px;margin-bottom: 0px; font-weight: 300\">{{appConfig.appName}}</mat-card-title>\r\n        </mat-card-header>\r\n\r\n        <mat-card-content>\r\n\r\n          <div class=\"tin-input mt-2\">\r\n\r\n            <spa-text id=\"txtuserName\" display=\"Username\" [(value)]=\"user.userName\"></spa-text>\r\n\r\n            <spa-text id=\"txtPassword\" display=\"Password\" format=\"password\" [(value)]=\"user.password\" (enterPress)=\"login()\"></spa-text>\r\n\r\n          </div>\r\n\r\n        </mat-card-content>\r\n\r\n\r\n        <mat-card-actions style=\"margin-bottom: 10px;\">\r\n\r\n          <div class=\"button mt-0\">\r\n            <button id=\"btnLogin\" mat-flat-button [disabled]=\"isProcessing\" style=\"width: 300px;\" (click)=\"login()\" color=\"primary\">Login</button>\r\n          </div>\r\n\r\n          <div class=\"button\" *ngIf=\"appConfig.selfService\" >\r\n            <button  id=\"btnSignup\" mat-stroked-button color=\"primary\" style=\"width: 300px;\" (click)=\"signup()\">Sign up with Email</button>\r\n          </div>\r\n\r\n          <div class=\"button\" *ngIf=\"appConfig.selfService\">\r\n            <asl-google-signin-button type='standard' width=\"300px\" size='medium' logo_alignment=\"center\" style=\"text-align: center;\"></asl-google-signin-button>\r\n          </div>\r\n\r\n\r\n\r\n\r\n\r\n        </mat-card-actions>\r\n\r\n      </mat-card>\r\n\r\n      <a *ngIf=\"appConfig.selfService\" mat-button id=\"lnkRecover\" style=\"margin-top: 1em\" (click)=\"recoverAccount()\">Forgot your password ?</a>\r\n\r\n\r\n\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <div *ngIf=\"style=='bs'\">\r\n\r\n    <div class=\"container\">\r\n\r\n      <div class=\"image\">\r\n        <img class=\"mb-4\" src=\"c:\\Tinashe\\Code\\Angular\\Junk\\bs-examples\\assets\\brand\\bootstrap-logo.svg\" alt=\"\" width=\"72\" height=\"57\">\r\n      </div>\r\n\r\n      <div class=\"details\">\r\n        <h1 class=\"h3 mb-3 fw-normal\" >Please sign in</h1>\r\n\r\n        <div class=\"form-floating\">\r\n          <input  class=\"form-control\" id=\"floatingInput\" placeholder=\"name@example.com\" [(ngModel)]=\"user.userName\">\r\n          <label for=\"floatingInput\">Username</label>\r\n        </div>\r\n\r\n        <div class=\"form-floating\">\r\n          <input type=\"password\" class=\"form-control\" id=\"floatingPassword\" placeholder=\"Password\" [(ngModel)]=\"user.password\">\r\n          <label for=\"floatingPassword\">Password</label>\r\n        </div>\r\n\r\n        <div class=\"form-check text-start my-3\">\r\n          <input class=\"form-check-input\" type=\"checkbox\" value=\"remember-me\" id=\"flexCheckDefault\" >\r\n          <label class=\"form-check-label\" for=\"flexCheckDefault\">\r\n            Remember me\r\n          </label>\r\n        </div>\r\n\r\n        <button class=\"btn btn-primary w-100 py-2\"  (click)=\"login()\">Sign in</button>\r\n\r\n      </div>\r\n\r\n      <p class=\"mt-5 mb-3 text-body-secondary\">&copy; 2017–2023</p>\r\n\r\n    </div>\r\n\r\n  </div>\r\n\r\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/login/login.component.ts","../../../../../../projects/tin-spa/src/lib/components/login/login.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MessageService } from \"../../services/message.service\";\r\nimport { StorageService } from \"../../services/storage.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { Component, OnInit, Input } from \"@angular/core\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { DataServiceLib } from \"../../services/data.service\";\r\nimport { LogService } from \"./../../services/log.service\";\r\nimport { User, AppConfig } from \"../../classes/Classes\";\r\nimport { HttpService } from \"../../services/http.service\";\r\nimport { ApiResponse, Constants } from \"../../classes/TinCore\";\r\nimport { SocialAuthService, SocialUser } from '@abacritt/angularx-social-login';\r\n\r\n@Component({\r\n  selector: \"spa-login\",\r\n  templateUrl: \"./login.component.html\",\r\n  styleUrls: [\"./login.component.css\"],\r\n})\r\nexport class LoginComponent implements OnInit {\r\n\r\n  constructor(private httpService: HttpService, private storageService: StorageService, public router: Router, private messageService: MessageService, public dataService: DataServiceLib,\r\n    public authService: AuthService, private logService: LogService, private route: ActivatedRoute, private socialService: SocialAuthService  ) { }\r\n\r\n  ngOnInit() {\r\n\r\n\r\n    this.dataService.appConfigObserv.subscribe(x => this.appConfig = x);\r\n\r\n    if (this.route.snapshot.queryParams[\"redirectTo\"] != undefined) {\r\n      this.redirectPath = this.route.snapshot.queryParams[\"redirectTo\"]\r\n    }else{\r\n      this.redirectPath = \"home\"\r\n    }\r\n\r\n\r\n\r\n    this.authService.autoLoginObserv.subscribe(x => {\r\n      this.autoLogin = x\r\n      console.log(\"AUTO LOGIN :\" + this.autoLogin)\r\n    })\r\n\r\n    this.socialUser = null;\r\n\r\n    this.socialService.authState.subscribe((socialUser: SocialUser) => {\r\n\r\n      this.socialUser = socialUser;\r\n\r\n      this.user.userName = socialUser.id;\r\n      this.user.password = \"x\"\r\n      this.user.token = socialUser.idToken;\r\n      this.user.authType = socialUser.provider;\r\n\r\n      this.login();\r\n\r\n    });\r\n\r\n    // this.authService.logoff();\r\n\r\n  }\r\n\r\n  autoLogin: boolean;\r\n  socialUser: SocialUser | null;\r\n\r\n  style: string = \"default\";\r\n\r\n  email: string = \"\";\r\n  password: string = \"\";\r\n\r\n  redirectPath\r\n\r\n  public user = new User();\r\n  hide = true;\r\n  isProcessing: boolean = false;\r\n\r\n  appConfig = new AppConfig();\r\n\r\n  public signup() {\r\n    this.router.navigate([\"signup\"]);\r\n  }\r\n\r\n  public recoverAccount() {\r\n    this.router.navigate([\"recover-account\"]);\r\n  }\r\n\r\n  public login() {\r\n\r\n\r\n    if (this.user.userName == \"\" || this.user.password == \"\") {\r\n      this.messageService.toast(\"Please enter your credentials\");\r\n      return;\r\n    }\r\n\r\n\r\n    this.logService.info(\"logging in\");\r\n\r\n    this.isProcessing = true;\r\n\r\n\r\n    this.user.userName = this.user.userName\r\n\r\n    this.dataService.Login(this.user).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      this.isProcessing = false;\r\n\r\n\r\n      if (apiResponse.success) {\r\n\r\n        // if (apiResponse.data.authType == 'local' && !this.appConfig.localAuth) {\r\n        //   this.messageService.toast(\"Contact Admin: Authentication Type error\");\r\n        //   return;\r\n        // }\r\n\r\n        // if (apiResponse.data.authType == 'AD' && !this.appConfig.ADAuth) {\r\n        //   this.messageService.toast(\"Contact Admin: Authentication Type error\");\r\n        //   return;\r\n        // }\r\n\r\n\r\n        this.authService.Updateloggedin(true);\r\n\r\n        this.authService.UpdateToken(apiResponse.data.token);\r\n        this.storageService.store(Constants.AUTH_TOKEN, apiResponse.data.token);\r\n\r\n        this.authService.UpdateTokenExpire(apiResponse.data.expiration);\r\n        this.storageService.store(Constants.AUTH_TOKEN_EXPIRE, apiResponse.data.expiration);\r\n\r\n        this.authService.UpdateCurrentUser(this.user.userName);\r\n        this.storageService.store(Constants.AUTH_USER, this.user.userName);\r\n\r\n        this.authService.updateLoggedUserFullName(apiResponse.data.firstName);\r\n        this.storageService.store(Constants.AUTH_NAME, apiResponse.data.firstName);\r\n\r\n        this.authService.UpdateRole(apiResponse.data.role);\r\n        this.storageService.store(Constants.AUTH_ROLES, JSON.stringify(apiResponse.data.role));\r\n\r\n        this.authService.updateTenantName(apiResponse.data.tenantName);\r\n        this.storageService.store(Constants.AUTH_TENANT_NAME, apiResponse.data.tenantName);\r\n\r\n\r\n        this.logService.info(\"logged in\");\r\n\r\n\r\n        if (apiResponse.data.changePassword == true && apiResponse.data.authType == 'local') {\r\n\r\n          this.router.navigate([\"home/user/change-password\"], {\r\n            queryParams: { redirectTo: this.redirectPath },\r\n            queryParamsHandling: 'merge',\r\n            skipLocationChange: false\r\n          });\r\n          return\r\n        }\r\n\r\n        this.router.navigate([this.redirectPath]);\r\n\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        this.user.password = \"\";\r\n      }\r\n    },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n}\r\n","\r\n  <div *ngIf=\"style=='old'\" class=\"tin-bg-login login-page\">\r\n\r\n    <div *ngIf=\"appConfig.logo!=''\" class=\"d-flex justify-content-center row align-items-center\" style=\"margin-top:3em;margin-bottom:1em\">\r\n\r\n      <img *ngIf=\"appConfig.logoSize=='normal'\"  [src]=\"appConfig.logo\" style=\"width: 100px;margin-right:3em;margin-left:3em\" />\r\n      <img *ngIf=\"appConfig.logoSize=='medium'\"  [src]=\"appConfig.logo\" style=\"width: 150px;margin-right:3em;margin-left:3em\" />\r\n      <img *ngIf=\"appConfig.logoSize=='large'\"  [src]=\"appConfig.logo\" style=\"width: 250px; margin-right:3em;margin-left:3em\" />\r\n\r\n    </div>\r\n\r\n\r\n    <div *ngIf=\"appConfig.logo ==''\" style=\"margin-top:2em\">\r\n        <!-- Add margin top when there is no logo -->\r\n    </div>\r\n\r\n\r\n    <div class=\"d-flex justify-content-center row align-items-center\" style=\"margin-top:3em;\">\r\n\r\n      <div class=\"d-none d-sm-block\">\r\n      </div>\r\n\r\n      <div style=\"margin-left:1em\">\r\n\r\n        <mat-card class=\"mat-elevation-z3 login-card\" style=\"width:400px; \">\r\n\r\n          <mat-card-header>\r\n            <mat-card-title>{{appConfig.appName}}</mat-card-title>\r\n          </mat-card-header>\r\n\r\n          <mat-card-content>\r\n\r\n            <div class=\"tin-input mt-2\">\r\n\r\n              <spa-text id=\"txtuserName\" display=\"Username\" [(value)]=\"user.userName\" ></spa-text>\r\n\r\n              <mat-form-field >\r\n                <mat-label>Password</mat-label>\r\n                <input id=\"txtPassword\" matInput [type]=\"hide ? 'password' : 'text'\"  (keyup.enter)=\"login()\" [(ngModel)]=\"user.password\" autocomplete=\"off\" >\r\n                <button mat-icon-button matSuffix (click)=\"hide = !hide\" [attr.aria-label]=\"'Hide password'\" [attr.aria-pressed]=\"hide\">\r\n                  <mat-icon style=\"font-size: 18px;\">{{hide ? 'visibility_off' : 'visibility'}}</mat-icon>\r\n                </button>\r\n              </mat-form-field>\r\n\r\n            </div>\r\n\r\n          </mat-card-content>\r\n\r\n\r\n          <mat-card-actions>\r\n\r\n            <div class=\"row \">\r\n\r\n              <div class=\"col d-flex justify-content-center\">\r\n                <button id=\"btnLogin\"  mat-raised-button [disabled]=\"isProcessing\" style=\"width: 100px;\" (click)=\"login()\" color=\"primary\">Login</button>\r\n              </div>\r\n\r\n              <div class=\"col d-flex justify-content-center\" *ngIf=\"appConfig.selfService\">\r\n                <button id=\"btnSignup\" mat-stroked-button  color=\"primary\" style=\"width: 100px;\" (click)=\"signup()\">Signup</button>\r\n              </div>\r\n\r\n            </div>\r\n\r\n          </mat-card-actions>\r\n\r\n        </mat-card>\r\n\r\n        <div *ngIf=\"appConfig.selfService\">\r\n          <br />\r\n          <a mat-button id=\"lnkRecover\"  style=\"margin-left: 1em\" (click)=\"recoverAccount()\">Forgot your password ?</a>\r\n        </div>\r\n\r\n      </div>\r\n\r\n    </div>\r\n\r\n  </div>\r\n\r\n\r\n  <div *ngIf=\"style=='default'\" class=\"login-page background tin-bg-login\">\r\n\r\n    <div class=\"container\" >\r\n\r\n      <div class=\"logo\">\r\n        <img *ngIf=\"appConfig.logoSize=='normal'\"  [src]=\"appConfig.logo\" style=\"width: 100px\" />\r\n        <img *ngIf=\"appConfig.logoSize=='medium'\"  [src]=\"appConfig.logo\" style=\"width: 150px\" />\r\n        <img *ngIf=\"appConfig.logoSize=='large'\"  [src]=\"appConfig.logo\" style=\"width: 250px\" />\r\n      </div>\r\n\r\n      <mat-card class=\"mat-elevation-z3 \" style=\"width:400px; \">\r\n\r\n        <mat-card-header>\r\n          <mat-card-title style=\"font-size: 40px;margin-bottom: 0px; font-weight: 300\">{{appConfig.appName}}</mat-card-title>\r\n        </mat-card-header>\r\n\r\n        <mat-card-content>\r\n\r\n          <div class=\"tin-input mt-2\">\r\n\r\n            <spa-text id=\"txtuserName\" display=\"Username\" [(value)]=\"user.userName\"></spa-text>\r\n\r\n            <spa-text id=\"txtPassword\" display=\"Password\" format=\"password\" [(value)]=\"user.password\" (enterPress)=\"login()\"></spa-text>\r\n\r\n          </div>\r\n\r\n        </mat-card-content>\r\n\r\n\r\n        <mat-card-actions style=\"margin-bottom: 10px;\">\r\n\r\n          <div class=\"button mt-0\">\r\n            <button id=\"btnLogin\" mat-flat-button [disabled]=\"isProcessing\" style=\"width: 300px;\" (click)=\"login()\" color=\"primary\">Login</button>\r\n          </div>\r\n\r\n          <div class=\"button\" *ngIf=\"appConfig.selfService\" >\r\n            <button  id=\"btnSignup\" mat-stroked-button color=\"primary\" style=\"width: 300px;\" (click)=\"signup()\">Sign up with Email</button>\r\n          </div>\r\n\r\n          <div class=\"button\" *ngIf=\"appConfig.selfService\">\r\n            <asl-google-signin-button type='standard' width=\"300px\" size='medium' logo_alignment=\"center\" style=\"text-align: center;\"></asl-google-signin-button>\r\n          </div>\r\n\r\n\r\n\r\n\r\n\r\n        </mat-card-actions>\r\n\r\n      </mat-card>\r\n\r\n      <a *ngIf=\"appConfig.selfService\" mat-button id=\"lnkRecover\" style=\"margin-top: 1em\" (click)=\"recoverAccount()\">Forgot your password ?</a>\r\n\r\n\r\n\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <div *ngIf=\"style=='bs'\">\r\n\r\n    <div class=\"container\">\r\n\r\n      <div class=\"image\">\r\n        <img class=\"mb-4\" src=\"c:\\Tinashe\\Code\\Angular\\Junk\\bs-examples\\assets\\brand\\bootstrap-logo.svg\" alt=\"\" width=\"72\" height=\"57\">\r\n      </div>\r\n\r\n      <div class=\"details\">\r\n        <h1 class=\"h3 mb-3 fw-normal\" >Please sign in</h1>\r\n\r\n        <div class=\"form-floating\">\r\n          <input  class=\"form-control\" id=\"floatingInput\" placeholder=\"name@example.com\" [(ngModel)]=\"user.userName\">\r\n          <label for=\"floatingInput\">Username</label>\r\n        </div>\r\n\r\n        <div class=\"form-floating\">\r\n          <input type=\"password\" class=\"form-control\" id=\"floatingPassword\" placeholder=\"Password\" [(ngModel)]=\"user.password\">\r\n          <label for=\"floatingPassword\">Password</label>\r\n        </div>\r\n\r\n        <div class=\"form-check text-start my-3\">\r\n          <input class=\"form-check-input\" type=\"checkbox\" value=\"remember-me\" id=\"flexCheckDefault\" >\r\n          <label class=\"form-check-label\" for=\"flexCheckDefault\">\r\n            Remember me\r\n          </label>\r\n        </div>\r\n\r\n        <button class=\"btn btn-primary w-100 py-2\"  (click)=\"login()\">Sign in</button>\r\n\r\n      </div>\r\n\r\n      <p class=\"mt-5 mb-3 text-body-secondary\">&copy; 2017–2023</p>\r\n\r\n    </div>\r\n\r\n  </div>\r\n\r\n"]}
|