tin-spa 2.6.6 → 2.6.7
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 +1 -1
- package/esm2020/lib/components/form/form.component.mjs +16 -1
- package/esm2020/lib/components/select/select.component.mjs +4 -4
- package/esm2020/lib/components/select-common/select-common.component.mjs +27 -2
- package/esm2020/lib/components/select-internal/select-internal.component.mjs +4 -4
- package/esm2020/lib/components/select-lite/select-lite.component.mjs +3 -3
- package/esm2020/lib/components/table/detailsDialog.component.mjs +3 -3
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +3 -3
- package/esm2020/lib/components/table-lite/detailsDialog-lite.component.mjs +3 -3
- package/fesm2015/tin-spa.mjs +60 -18
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +53 -15
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +2 -0
- package/lib/components/select-common/select-common.component.d.ts +7 -4
- package/package.json +1 -1
|
@@ -88,4 +88,4 @@ export class FinAccount {
|
|
|
88
88
|
this.currency = "";
|
|
89
89
|
}
|
|
90
90
|
}
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Classes.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/classes/Classes.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,WAAW;CAIvB;AAED,MAAM,OAAO,SAAS;;AACG,mBAAS,GAAG,GAAG,CAAC;AAChB,mBAAS,GAAG,GAAG,CAAC;AAChB,oBAAU,GAAG,GAAG,CAAC;AACjB,oBAAU,GAAG,GAAG,CAAC;AACjB,2BAAiB,GAAG,GAAG,CAAC;AACxB,0BAAgB,GAAG,GAAG,CAAC;AAGhD,MAAM,OAAO,gBAAgB;CAI5B;AAED,MAAM,CAAN,IAAY,aAAwB;AAApC,WAAY,aAAa;IAAE,+CAAG,CAAA;IAAE,+CAAG,CAAA;AAAA,CAAC,EAAxB,aAAa,KAAb,aAAa,QAAW;AAEpC,MAAM,OAAO,mBAAmB;CAiB/B;AAED,MAAM,OAAO,aAAa;CAGzB;AAED,MAAM,OAAO,MAAM;CAOlB;AAID,MAAM,OAAO,YAAY;CAKxB;AAQD,MAAM,OAAO,aAAa;CAKzB;AAED,MAAM,OAAO,YAAY;CAIxB;AAID,MAAM,OAAO,UAAU;CActB;AA2BD,MAAM,OAAO,UAAU;CAKtB;AAwDD,MAAM,OAAO,WAAW;CAgCvB;AAiCD,MAAM,OAAO,UAAU;CAMtB;AAeD,MAAM,OAAO,UAAU;CAGtB;AAED,MAAM,OAAO,IAAI;CAKhB;AAID,MAAM,OAAO,cAAc;CAG1B;AAMD,MAAM,OAAO,SAAS;IACpB;QACE,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;CAcF;AAED,MAAM,OAAO,OAAO;IAElB;QACE,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAE9B,CAAC;CAcF;AAID,MAAM,OAAO,WAAW;IAEtB;QACE,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IACtB,CAAC;CAWF;AAED,MAAM,OAAO,UAAU;IAErB;QACE,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IAErB,CAAC;CAQF","sourcesContent":["import { Core } from \"./TinCore\";\r\n\r\nexport class ApiResponse {\r\n  success: boolean;\r\n  message: string;\r\n  data;\r\n}\r\n\r\nexport class Constants {\r\n  public static readonly AUTH_USER = 'a';\r\n  public static readonly AUTH_NAME = 'b';\r\n  public static readonly AUTH_ROLES = 'c';\r\n  public static readonly AUTH_TOKEN = 'd';\r\n  public static readonly AUTH_TOKEN_EXPIRE = 'e';\r\n  public static readonly AUTH_TENANT_NAME = 'f';\r\n}\r\n\r\nexport class ListDialogConfig{\r\n  name: string;\r\n  title: string;\r\n  listName: string;\r\n}\r\n\r\nexport enum DetailsSource {Row, Url}\r\n\r\nexport class DetailsDialogConfig {\r\n\r\n  stepConfig? : StepConfig;\r\n  formConfig: FormConfig;\r\n  tableConfig?: TableConfig;\r\n  tableConfigs?: TableConfig[];\r\n  buttons?: Button[];\r\n  details? : any\r\n  heroField? : any\r\n  heroValue?: any\r\n  mode?: 'create' | 'edit' | 'view'\r\n  width?: string\r\n  // setHero ?: boolean\r\n  detailsSource?: DetailsSource\r\n  // sourceMethod : 'row' | 'id' | 'idField'\r\n  // row?: any\r\n  options?: dialogOptions\r\n}\r\n\r\nexport class dialogOptions {\r\n  width?: string;\r\n  height?: string;\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  forceRefresh?: boolean\r\n}\r\n\r\n\r\n\r\nexport class SearchConfig {\r\n  fields: SearchField[]\r\n  searchAction?: Action\r\n  emailResults?: boolean\r\n  tileConfig?: TileConfig\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 AlertMessages {\r\n\r\n  subject? : string\r\n  messages: AlertMessage[]\r\n\r\n}\r\n\r\nexport class AlertMessage {\r\n  type?: 'success' |'info' | 'warn' | 'critical'\r\n  content: string\r\n  hiddenCondition?: (value: any) => boolean;\r\n}\r\n\r\n\r\n\r\nexport class FormConfig {\r\n  title?: string\r\n  fixedTitle?: boolean\r\n  alertMessages?: AlertMessages\r\n  fields: Field[]\r\n  mode?: 'create' | 'edit' | 'view'\r\n  button? : Button\r\n  multiColumn?: boolean\r\n  reset?: boolean\r\n  // fileAction?: Action\r\n  loadAction?: Action\r\n  heroField?: any\r\n  heroValue?: any\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  inDialog?: boolean\r\n  inHeader?: boolean\r\n  detailsConfig?: DetailsDialogConfig\r\n  setHeroField?: boolean;\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 class PageConfig {\r\n\r\n  title?: string;\r\n  tableConfig?: TableConfig;\r\n  searchTableConfig?: TableConfig;\r\n}\r\n\r\nexport interface Field {\r\n  name: string;\r\n  type: 'text' | 'multi-text'| 'password' | 'date' | 'datetime' | 'datetimesec' | 'checkbox' | 'select' | 'multi-select' | 'money' | 'number' | 'section' | 'blank' | 'chip' | 'file' | 'file-view' | 'icon' | 'spinner' | 'button' | 'label' | 'email' | 'composite' | 'string';\r\n  alias?: string;\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n  masterOptionValue?: string\r\n  defaultValue?: any\r\n  defaultFirstValue?: boolean\r\n  required?: boolean\r\n  min?: any\r\n  max?: any\r\n  rows?: number\r\n  span?: boolean\r\n  width?: string\r\n  size?: string\r\n  readonly?: boolean\r\n  hidden?: boolean\r\n  strict?: boolean\r\n  path?: string\r\n  keyField?: string\r\n  hint?: string\r\n  masterField?: string\r\n  child?: ChildField\r\n  children?: ChildField[]\r\n  masterOptions?: any[]\r\n  nullable ?: boolean\r\n  copyContent?: boolean\r\n  clearContent?: boolean\r\n  format?: 'text' | 'money' | 'date' | 'datetime'\r\n  hideOnCreate ?: boolean\r\n  hideOnExists ?: boolean\r\n  hiddenCondition?: (value: any) => boolean;\r\n  readonlyCondition?: (value: any) => boolean;\r\n\r\n  detailsConfig ?: DetailsDialogConfig;\r\n\r\n  loadAction?: Action\r\n\r\n  infoMessage?: string;\r\n  suffix?: string;\r\n\r\n  subfields?: Field[];\r\n\r\n}\r\n\r\n\r\n\r\nexport interface ChildField {\r\n  childField?: string\r\n  childValueField?: string\r\n}\r\n\r\nexport class TableConfig{\r\n  title?: string\r\n  noDataMessage ?: string\r\n  columns? : Column[]\r\n  minColumns?: string[]\r\n  showFilter?: boolean\r\n  showFilterButton?: boolean\r\n  holdFilterSpace?: boolean\r\n  holdHeaderButtonSpace?: boolean\r\n  elevation?: 'none' | 'low' | 'medium' | 'high'\r\n  formConfig?: FormConfig\r\n  searchConfig?: SearchConfig\r\n  tileConfig?: TileConfig\r\n  stepConfig?: StepConfig\r\n  buttons?: Button[]\r\n  minButtons?: string[]\r\n  loadAction?: Action\r\n  loadIDField ?: string\r\n  loadCriteria?: string\r\n  logResponse?: boolean\r\n  flatButtons?: boolean\r\n  greyOut?: (value: any) => boolean;\r\n  heroField?: any\r\n  heroValue?: any\r\n  collapseButtons?: boolean\r\n  parentData ? : any\r\n  pageSizes?: number[]\r\n  maxButtons?: number\r\n  hideTabCondition?: (value: any) => boolean;\r\n\r\n  download?: { columns: string[], fileName?: string, hiddenCondition?: (value: any) => boolean; }\r\n  upload?: { action: Action, messages?: AlertMessage[], hiddenCondition?: (value: any) => boolean; }\r\n}\r\n\r\nexport interface Column {\r\n  name: string;\r\n  type?: 'text' | 'date' | 'datetime' | 'datetimesec' | 'checkbox' | 'select' | 'money' | 'number' | 'chip' | 'icon' | 'spinner' | 'button' ;\r\n  alias?: string;\r\n  max?: number;\r\n  icon?: Icon;\r\n  color?: Color;\r\n  colors?: Color[];\r\n  icons?: Icon[];\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n  detailsConfig?: DetailsDialogConfig\r\n  hiddenCondition?: (parentData: any) => boolean;\r\n}\r\n\r\nexport interface Icon{\r\n  name: string\r\n  color?: string\r\n  tip?: string\r\n  tipField?: string\r\n  bannerField?: 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  action?: Action;\r\n}\r\n\r\nexport class StepConfig{\r\n  steps : Step[]\r\n  valueField?: string\r\n}\r\n\r\nexport class Step {\r\n  name: string\r\n  value?: any\r\n  icon?: string;\r\n  hiddenCondition?: (value: any) => boolean;\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\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.googleAuth = false;\r\n    this.selfService = false;\r\n    this.multitenant = false;\r\n    this.navigation = 'top';\r\n    this.progressLine = 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  googleAuth: boolean;\r\n  selfService: boolean;\r\n  capItems: CapItem[];\r\n  multitenant : boolean;\r\n  navigation : 'top' | 'side'\r\n  progressLine: boolean;\r\n  docsBaseUrl : string;\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\n\r\nexport class Transaction {\r\n\r\n  constructor() {\r\n    this.transactionID = 0;\r\n    this.narration = \"\";\r\n    this.amount = '0';\r\n    this.type = 0;\r\n    this.date = \"\";\r\n    this.accountID = 0;\r\n    this.destinationID = 0;\r\n    this.categoryID = 0;\r\n  }\r\n\r\n  transactionID : number;\r\n  narration : string;\r\n  amount : string;\r\n  type: number;\r\n  date : string;\r\n  accountID : number;\r\n  destinationID : number;\r\n  categoryID : number;\r\n\r\n}\r\n\r\nexport class FinAccount {\r\n\r\n  constructor(){\r\n    this.accountID = 0;\r\n    this.name = \"\";\r\n    this.description = \"\";\r\n    this.currency = \"\";\r\n\r\n  }\r\n\r\n\r\n  accountID: number\r\n  name: string;\r\n  description: string;\r\n  currency: string;\r\n\r\n}\r\n\r\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Classes.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/classes/Classes.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,WAAW;CAIvB;AAED,MAAM,OAAO,SAAS;;AACG,mBAAS,GAAG,GAAG,CAAC;AAChB,mBAAS,GAAG,GAAG,CAAC;AAChB,oBAAU,GAAG,GAAG,CAAC;AACjB,oBAAU,GAAG,GAAG,CAAC;AACjB,2BAAiB,GAAG,GAAG,CAAC;AACxB,0BAAgB,GAAG,GAAG,CAAC;AAGhD,MAAM,OAAO,gBAAgB;CAI5B;AAED,MAAM,CAAN,IAAY,aAAwB;AAApC,WAAY,aAAa;IAAE,+CAAG,CAAA;IAAE,+CAAG,CAAA;AAAA,CAAC,EAAxB,aAAa,KAAb,aAAa,QAAW;AAEpC,MAAM,OAAO,mBAAmB;CAiB/B;AAED,MAAM,OAAO,aAAa;CAGzB;AAED,MAAM,OAAO,MAAM;CAOlB;AAID,MAAM,OAAO,YAAY;CAKxB;AAQD,MAAM,OAAO,aAAa;CAKzB;AAED,MAAM,OAAO,YAAY;CAIxB;AAID,MAAM,OAAO,UAAU;CActB;AA2BD,MAAM,OAAO,UAAU;CAKtB;AA0DD,MAAM,OAAO,WAAW;CAgCvB;AAiCD,MAAM,OAAO,UAAU;CAMtB;AAeD,MAAM,OAAO,UAAU;CAGtB;AAED,MAAM,OAAO,IAAI;CAKhB;AAID,MAAM,OAAO,cAAc;CAG1B;AAMD,MAAM,OAAO,SAAS;IACpB;QACE,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;CAcF;AAED,MAAM,OAAO,OAAO;IAElB;QACE,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAE9B,CAAC;CAcF;AAID,MAAM,OAAO,WAAW;IAEtB;QACE,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IACtB,CAAC;CAWF;AAED,MAAM,OAAO,UAAU;IAErB;QACE,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IAErB,CAAC;CAQF","sourcesContent":["import { BehaviorSubject } from \"rxjs\";\r\nimport { Core } from \"./TinCore\";\r\n\r\nexport class ApiResponse {\r\n  success: boolean;\r\n  message: string;\r\n  data;\r\n}\r\n\r\nexport class Constants {\r\n  public static readonly AUTH_USER = 'a';\r\n  public static readonly AUTH_NAME = 'b';\r\n  public static readonly AUTH_ROLES = 'c';\r\n  public static readonly AUTH_TOKEN = 'd';\r\n  public static readonly AUTH_TOKEN_EXPIRE = 'e';\r\n  public static readonly AUTH_TENANT_NAME = 'f';\r\n}\r\n\r\nexport class ListDialogConfig{\r\n  name: string;\r\n  title: string;\r\n  listName: string;\r\n}\r\n\r\nexport enum DetailsSource {Row, Url}\r\n\r\nexport class DetailsDialogConfig {\r\n\r\n  stepConfig? : StepConfig;\r\n  formConfig: FormConfig;\r\n  tableConfig?: TableConfig;\r\n  tableConfigs?: TableConfig[];\r\n  buttons?: Button[];\r\n  details? : any\r\n  heroField? : any\r\n  heroValue?: any\r\n  mode?: 'create' | 'edit' | 'view'\r\n  width?: string\r\n  // setHero ?: boolean\r\n  detailsSource?: DetailsSource\r\n  // sourceMethod : 'row' | 'id' | 'idField'\r\n  // row?: any\r\n  options?: dialogOptions\r\n}\r\n\r\nexport class dialogOptions {\r\n  width?: string;\r\n  height?: string;\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  forceRefresh?: boolean\r\n}\r\n\r\n\r\n\r\nexport class SearchConfig {\r\n  fields: SearchField[]\r\n  searchAction?: Action\r\n  emailResults?: boolean\r\n  tileConfig?: TileConfig\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 AlertMessages {\r\n\r\n  subject? : string\r\n  messages: AlertMessage[]\r\n\r\n}\r\n\r\nexport class AlertMessage {\r\n  type?: 'success' |'info' | 'warn' | 'critical'\r\n  content: string\r\n  hiddenCondition?: (value: any) => boolean;\r\n}\r\n\r\n\r\n\r\nexport class FormConfig {\r\n  title?: string\r\n  fixedTitle?: boolean\r\n  alertMessages?: AlertMessages\r\n  fields: Field[]\r\n  mode?: 'create' | 'edit' | 'view'\r\n  button? : Button\r\n  multiColumn?: boolean\r\n  reset?: boolean\r\n  // fileAction?: Action\r\n  loadAction?: Action\r\n  heroField?: any\r\n  heroValue?: any\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  inDialog?: boolean\r\n  inHeader?: boolean\r\n  detailsConfig?: DetailsDialogConfig\r\n  setHeroField?: boolean;\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 class PageConfig {\r\n\r\n  title?: string;\r\n  tableConfig?: TableConfig;\r\n  searchTableConfig?: TableConfig;\r\n}\r\n\r\nexport interface Field {\r\n  name: string;\r\n  type: 'text' | 'multi-text'| 'password' | 'date' | 'datetime' | 'datetimesec' | 'checkbox' | 'select' | 'multi-select' | 'money' | 'number' | 'section' | 'blank' | 'chip' | 'file' | 'file-view' | 'icon' | 'spinner' | 'button' | 'label' | 'email' | 'composite' | 'string';\r\n  alias?: string;\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n  masterOptionValue?: string\r\n  defaultValue?: any\r\n  defaultFirstValue?: boolean\r\n  required?: boolean\r\n  min?: any\r\n  max?: any\r\n  rows?: number\r\n  span?: boolean\r\n  width?: string\r\n  size?: string\r\n  readonly?: boolean\r\n  hidden?: boolean\r\n  strict?: boolean\r\n  path?: string\r\n  keyField?: string\r\n  hint?: string\r\n  masterField?: string\r\n  child?: ChildField\r\n  children?: ChildField[]\r\n  masterOptions?: any[]\r\n  nullable ?: boolean\r\n  copyContent?: boolean\r\n  clearContent?: boolean\r\n  format?: 'text' | 'money' | 'date' | 'datetime'\r\n  hideOnCreate ?: boolean\r\n  hideOnExists ?: boolean\r\n  hiddenCondition?: (value: any) => boolean;\r\n  readonlyCondition?: (value: any) => boolean;\r\n\r\n  detailsConfig ?: DetailsDialogConfig;\r\n\r\n  loadAction?: Action\r\n\r\n  infoMessage?: string;\r\n  suffix?: string;\r\n\r\n  subfields?: Field[];\r\n\r\n  optionsSubject?: BehaviorSubject<any[]>;\r\n\r\n}\r\n\r\n\r\n\r\nexport interface ChildField {\r\n  childField?: string\r\n  childValueField?: string\r\n}\r\n\r\nexport class TableConfig{\r\n  title?: string\r\n  noDataMessage ?: string\r\n  columns? : Column[]\r\n  minColumns?: string[]\r\n  showFilter?: boolean\r\n  showFilterButton?: boolean\r\n  holdFilterSpace?: boolean\r\n  holdHeaderButtonSpace?: boolean\r\n  elevation?: 'none' | 'low' | 'medium' | 'high'\r\n  formConfig?: FormConfig\r\n  searchConfig?: SearchConfig\r\n  tileConfig?: TileConfig\r\n  stepConfig?: StepConfig\r\n  buttons?: Button[]\r\n  minButtons?: string[]\r\n  loadAction?: Action\r\n  loadIDField ?: string\r\n  loadCriteria?: string\r\n  logResponse?: boolean\r\n  flatButtons?: boolean\r\n  greyOut?: (value: any) => boolean;\r\n  heroField?: any\r\n  heroValue?: any\r\n  collapseButtons?: boolean\r\n  parentData ? : any\r\n  pageSizes?: number[]\r\n  maxButtons?: number\r\n  hideTabCondition?: (value: any) => boolean;\r\n\r\n  download?: { columns: string[], fileName?: string, hiddenCondition?: (value: any) => boolean; }\r\n  upload?: { action: Action, messages?: AlertMessage[], hiddenCondition?: (value: any) => boolean; }\r\n}\r\n\r\nexport interface Column {\r\n  name: string;\r\n  type?: 'text' | 'date' | 'datetime' | 'datetimesec' | 'checkbox' | 'select' | 'money' | 'number' | 'chip' | 'icon' | 'spinner' | 'button' ;\r\n  alias?: string;\r\n  max?: number;\r\n  icon?: Icon;\r\n  color?: Color;\r\n  colors?: Color[];\r\n  icons?: Icon[];\r\n  options?: any[];\r\n  optionDisplay?: string\r\n  optionValue?: string\r\n  detailsConfig?: DetailsDialogConfig\r\n  hiddenCondition?: (parentData: any) => boolean;\r\n}\r\n\r\nexport interface Icon{\r\n  name: string\r\n  color?: string\r\n  tip?: string\r\n  tipField?: string\r\n  bannerField?: 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  action?: Action;\r\n}\r\n\r\nexport class StepConfig{\r\n  steps : Step[]\r\n  valueField?: string\r\n}\r\n\r\nexport class Step {\r\n  name: string\r\n  value?: any\r\n  icon?: string;\r\n  hiddenCondition?: (value: any) => boolean;\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\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.googleAuth = false;\r\n    this.selfService = false;\r\n    this.multitenant = false;\r\n    this.navigation = 'top';\r\n    this.progressLine = 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  googleAuth: boolean;\r\n  selfService: boolean;\r\n  capItems: CapItem[];\r\n  multitenant : boolean;\r\n  navigation : 'top' | 'side'\r\n  progressLine: boolean;\r\n  docsBaseUrl : string;\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\n\r\nexport class Transaction {\r\n\r\n  constructor() {\r\n    this.transactionID = 0;\r\n    this.narration = \"\";\r\n    this.amount = '0';\r\n    this.type = 0;\r\n    this.date = \"\";\r\n    this.accountID = 0;\r\n    this.destinationID = 0;\r\n    this.categoryID = 0;\r\n  }\r\n\r\n  transactionID : number;\r\n  narration : string;\r\n  amount : string;\r\n  type: number;\r\n  date : string;\r\n  accountID : number;\r\n  destinationID : number;\r\n  categoryID : number;\r\n\r\n}\r\n\r\nexport class FinAccount {\r\n\r\n  constructor(){\r\n    this.accountID = 0;\r\n    this.name = \"\";\r\n    this.description = \"\";\r\n    this.currency = \"\";\r\n\r\n  }\r\n\r\n\r\n  accountID: number\r\n  name: string;\r\n  description: string;\r\n  currency: string;\r\n\r\n}\r\n\r\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Component, ContentChild, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { Core } from '../../classes/TinCore';
|
|
3
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "../../services/message.service";
|
|
5
6
|
import * as i2 from "../../services/datalib.service";
|
|
@@ -39,6 +40,20 @@ export class FormComponent {
|
|
|
39
40
|
return;
|
|
40
41
|
}
|
|
41
42
|
this.fields = this.config.fields;
|
|
43
|
+
// Initialize BehaviorSubjects for fields with loadActions
|
|
44
|
+
this.fields?.forEach(field => {
|
|
45
|
+
if (field.loadAction && !field.optionsSubject && !field.masterField) {
|
|
46
|
+
field.optionsSubject = new BehaviorSubject([]);
|
|
47
|
+
// Subscribe to options changes
|
|
48
|
+
field.optionsSubject.subscribe(newOptions => {
|
|
49
|
+
field.options = newOptions;
|
|
50
|
+
// Update child fields that depend on this field
|
|
51
|
+
if (this.childFields?.some(x => x.masterField === field.name)) {
|
|
52
|
+
this.updateChildOptions(field.name);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
});
|
|
42
57
|
if (this.config.multiColumn) {
|
|
43
58
|
this.multiColumn = this.config.multiColumn;
|
|
44
59
|
}
|
|
@@ -225,4 +240,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
225
240
|
}], inputChange: [{
|
|
226
241
|
type: Output
|
|
227
242
|
}] } });
|
|
228
|
-
//# 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, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { FormConfig, Field, Button, ApiResponse } from '../../classes/Classes';\r\nimport { Core } from '../../classes/TinCore';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnInit {\r\n\r\n  constructor( private messageService: MessageService, private dataService: DataServiceLib) { }\r\n\r\n  ngOnInit() {\r\n\r\n    if (!this.config.fields){\r\n      this.messageService.toast(\"Please Configure Form Fields\")\r\n      return;\r\n    }\r\n\r\n    if (!this.data) {\r\n      this.messageService.toast(\"Please Configure Form Data\")\r\n      return;\r\n    }\r\n\r\n    this.fields = this.config.fields;\r\n\r\n\r\n    if (this.config.multiColumn){\r\n      this.multiColumn = this.config.multiColumn\r\n    }else{\r\n      this.multiColumn = this.fields.length > 2\r\n    }\r\n\r\n    if (this.config?.button?.display){\r\n      this.buttonDisplay = this.config.button.display;\r\n    }\r\n\r\n    this.fileField = this.fields.find(x => x.type == 'file')\r\n\r\n    if (this.config?.button?.action && this.fileField) {\r\n      this.config.button.action.isFormData = true;\r\n\r\n    }\r\n\r\n    this.childFields = this.fields.filter(x => x.masterField)\r\n\r\n\r\n    this.childFields.forEach(child => {\r\n      let master = this.fields.find(x => x.name == child.masterField)\r\n      if (child.loadAction) {\r\n        this.loadChildMasterOptions(child);\r\n      }else{\r\n        this.updateChildOptions(master.name);\r\n      }\r\n\r\n    });\r\n\r\n    this.fields.forEach(field => {\r\n      if (field.loadAction) {\r\n        this.loadChildMasterOptions(field);\r\n      }\r\n    });\r\n\r\n    this.initializeCompositeFields();\r\n\r\n\r\n  }\r\n\r\n  initializeCompositeFields() {\r\n    this.fields.forEach(field => {\r\n      if (field.type === 'composite' && field.subfields) {\r\n        field.subfields.forEach(subfield => {\r\n          if (this.data[subfield.name] === undefined) {\r\n            this.data[subfield.name] = Core.getInitialValue(subfield);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  getVisibleSubfields(field : Field){\r\n    return Core.getVisibleSubfields(this.config, this.data, field);\r\n  }\r\n\r\n\r\n  getVisibleFields(){\r\n    return this.fields?.filter(x => Core.testVisible(this.config, this.data, x))\r\n  }\r\n\r\n  testReadOnly(f: Field): boolean {\r\n\r\n\r\n    if (this.config.mode == 'create') {\r\n      return false;\r\n    }\r\n\r\n    if (f.readonly) return true;\r\n\r\n    if (this.config.mode == 'view') {\r\n      return true;\r\n    }\r\n\r\n\r\n    if (f.readonlyCondition) {\r\n      return f.readonlyCondition(this.data);\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  @ContentChild('dynamicSelect') dynamicSelectTemplate: TemplateRef<any>;\r\n  fileNames\r\n  fileField: Field;\r\n  fileViewField: Field;\r\n  @Input() files: any[] = [];\r\n  fields: Field[];\r\n  buttonDisplay = \"Submit\";\r\n  isProcessing : boolean = false;\r\n  multiColumn : boolean = false;\r\n\r\n  childFields : Field[];\r\n\r\n  @Input() data: any;\r\n  @Input() config: FormConfig;\r\n  @Output() buttonClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  selectChanged(field: Field){\r\n    this.inputChanged(field, this.data[field.name] )\r\n  }\r\n\r\n  inputChanged(field : Field, value){\r\n\r\n\r\n    this.inputChange.emit({ field: field, value: value})\r\n\r\n    this.updateChildOptions(field.name)\r\n\r\n    if (this.config.mode == 'create' && field.child){\r\n\r\n      let child = this.fields.find(x => x.name == field.child.childField)\r\n      this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[field.child.childValueField]\r\n\r\n    }\r\n\r\n\r\n    if (this.config.mode == 'create' && field.children){\r\n      console.log(\"Children found\")\r\n\r\n      field.children.forEach(childConfig => {\r\n\r\n        let child = this.fields.find(x => x.name == childConfig.childField)\r\n        console.log(\"Child found\")\r\n\r\n        this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[childConfig.childValueField]\r\n\r\n      });\r\n\r\n    }\r\n\r\n  }\r\n\r\n  updateChildOptions(masterFieldName: string){\r\n\r\n    let child = this.childFields.find(x => x.masterField == masterFieldName)\r\n    if (child != null) {\r\n\r\n      //current is master\r\n\r\n\r\n      if (child.masterOptions){\r\n        child.options = child.masterOptions.filter(x => x[child.masterOptionValue] == this.data[masterFieldName])\r\n      }else{\r\n        console.log(\"Master Options not found\")\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private loadChildMasterOptions(child: Field) {\r\n    if (!child.loadAction) return;\r\n\r\n    this.dataService.CallApi(child.loadAction).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        child.masterOptions = apiResponse.data;\r\n        this.updateChildOptions(child.masterField);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  buttonClicked(){\r\n\r\n    this.buttonClick.emit(this.data);\r\n\r\n    let button = this.config.button;\r\n\r\n    if (!button) {\r\n      return;\r\n    }\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.getVisibleFields(),this.data);\r\n    if (resp != ''){\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n\r\n\r\n    if (button.confirm){\r\n\r\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.processCall(button)\r\n        }\r\n      });\r\n\r\n    }else{\r\n      this.processCall(button)\r\n    }\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n  processCall(button: Button){\r\n\r\n    if (!button.action) return\r\n\r\n    let dataOut;\r\n\r\n    if (button.action.isFormData){\r\n\r\n      let formData: FormData = new FormData();\r\n      for (let i = 0; i < this.files.length; i++) {\r\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\r\n      }\r\n\r\n      formData.append(\"data\", JSON.stringify(this.data));\r\n\r\n\r\n      dataOut = formData\r\n    }else{\r\n\r\n      dataOut = this.data\r\n    }\r\n\r\n\r\n\r\n\r\n    this.isProcessing = true\r\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\r\n      this.isProcessing = false\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Submitted\");\r\n        }\r\n\r\n        if (this.config.reset) {\r\n          Core.resetObject(this.fields, this.data)\r\n          this.files = [];\r\n        }\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  processForm(){\r\n\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\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  >\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]=\"field.loadAction\" [path]=\"field.path\" [folderName]=\"data[field.keyField]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}}</label>\r\n\r\n        <spa-label *ngSwitchCase=\"'label'\" [display]=\"field.alias ?? field.name | camelToWords\" [value]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [format]=\"field.format ?? 'text'\" ></spa-label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></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]=\"testReadOnly(field)\" [infoMessage]=\"field.infoMessage\" ></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></spa-date>\r\n\r\n        <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [min]=\"field.min\" [max]=\"field.max\" [infoMessage]=\"field.infoMessage\" ></spa-datetime>\r\n\r\n        <spa-email *ngSwitchCase=\"'email'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-email>\r\n\r\n        <spa-text *ngSwitchCase=\"'password'\" [format]=\"'password'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [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]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-text>\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'select'\">\r\n          <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                  $implicit: field,\r\n                  field: field,\r\n                  data: data,\r\n                  testReadOnly: testReadOnly.bind(this),\r\n                  selectChanged: selectChanged.bind(this)\r\n                }\">\r\n          </ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <spa-multi-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\">\r\n        </spa-multi-select>\r\n\r\n        <spa-multi-text *ngSwitchCase=\"'multi-text'\" [strict]=\"field.strict\" [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])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-multi-text>\r\n\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'composite'\">\r\n          <div class=\"composite-field-container\">\r\n            <div class=\"composite-field-group\">\r\n              <ng-container *ngFor=\"let subfield of getVisibleSubfields(field)\">\r\n                <ng-container [ngSwitch]=\"subfield.type\">\r\n\r\n                  <spa-number *ngSwitchCase=\"'number'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\"></spa-number>\r\n\r\n                  <spa-money *ngSwitchCase=\"'money'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-money>\r\n\r\n                  <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [infoMessage]=\"subfield.infoMessage\" ></spa-check>\r\n\r\n                  <spa-date *ngSwitchCase=\"'date'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-date>\r\n\r\n                  <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [infoMessage]=\"subfield.infoMessage\" ></spa-datetime>\r\n\r\n                  <ng-container *ngSwitchCase=\"'select'\">\r\n                    <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                                    $implicit: field,\r\n                                    field: field,\r\n                                    data: data,\r\n                                    testReadOnly: testReadOnly.bind(this),\r\n                                    selectChanged: selectChanged.bind(this)\r\n                                  }\">\r\n                    </ng-container>\r\n                  </ng-container>\r\n\r\n                  <spa-text *ngSwitchDefault [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\"  [options]=\"subfield.options\" [optionDisplay]=\"subfield.optionDisplay ?? 'name'\" [optionValue]=\"subfield.optionValue ?? 'value'\" [rows]=\"subfield.rows\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\" [loadAction]=\"subfield.loadAction\"></spa-text>\r\n\r\n\r\n                </ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [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]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></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"]}
|
|
243
|
+
//# 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, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { FormConfig, Field, Button, ApiResponse } from '../../classes/Classes';\r\nimport { Core } from '../../classes/TinCore';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnInit {\r\n\r\n  constructor( private messageService: MessageService, private dataService: DataServiceLib) { }\r\n\r\n  ngOnInit() {\r\n\r\n    if (!this.config.fields){\r\n      this.messageService.toast(\"Please Configure Form Fields\")\r\n      return;\r\n    }\r\n\r\n    if (!this.data) {\r\n      this.messageService.toast(\"Please Configure Form Data\")\r\n      return;\r\n    }\r\n\r\n    this.fields = this.config.fields;\r\n\r\n    // Initialize BehaviorSubjects for fields with loadActions\r\n    this.fields?.forEach(field => {\r\n      if (field.loadAction && !field.optionsSubject && !field.masterField) {\r\n        field.optionsSubject = new BehaviorSubject<any[]>([]);\r\n\r\n        // Subscribe to options changes\r\n        field.optionsSubject.subscribe(newOptions => {\r\n          field.options = newOptions;\r\n\r\n          // Update child fields that depend on this field\r\n          if (this.childFields?.some(x => x.masterField === field.name)) {\r\n            this.updateChildOptions(field.name);\r\n          }\r\n        });\r\n      }\r\n    });\r\n\r\n\r\n    if (this.config.multiColumn){\r\n      this.multiColumn = this.config.multiColumn\r\n    }else{\r\n      this.multiColumn = this.fields.length > 2\r\n    }\r\n\r\n    if (this.config?.button?.display){\r\n      this.buttonDisplay = this.config.button.display;\r\n    }\r\n\r\n    this.fileField = this.fields.find(x => x.type == 'file')\r\n\r\n    if (this.config?.button?.action && this.fileField) {\r\n      this.config.button.action.isFormData = true;\r\n\r\n    }\r\n\r\n    this.childFields = this.fields.filter(x => x.masterField)\r\n\r\n\r\n    this.childFields.forEach(child => {\r\n      let master = this.fields.find(x => x.name == child.masterField)\r\n      if (child.loadAction) {\r\n        this.loadChildMasterOptions(child);\r\n      }else{\r\n        this.updateChildOptions(master.name);\r\n      }\r\n\r\n    });\r\n\r\n    this.fields.forEach(field => {\r\n      if (field.loadAction) {\r\n        this.loadChildMasterOptions(field);\r\n      }\r\n    });\r\n\r\n    this.initializeCompositeFields();\r\n\r\n\r\n  }\r\n\r\n  initializeCompositeFields() {\r\n    this.fields.forEach(field => {\r\n      if (field.type === 'composite' && field.subfields) {\r\n        field.subfields.forEach(subfield => {\r\n          if (this.data[subfield.name] === undefined) {\r\n            this.data[subfield.name] = Core.getInitialValue(subfield);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  getVisibleSubfields(field : Field){\r\n    return Core.getVisibleSubfields(this.config, this.data, field);\r\n  }\r\n\r\n\r\n  getVisibleFields(){\r\n    return this.fields?.filter(x => Core.testVisible(this.config, this.data, x))\r\n  }\r\n\r\n  testReadOnly(f: Field): boolean {\r\n\r\n\r\n    if (this.config.mode == 'create') {\r\n      return false;\r\n    }\r\n\r\n    if (f.readonly) return true;\r\n\r\n    if (this.config.mode == 'view') {\r\n      return true;\r\n    }\r\n\r\n\r\n    if (f.readonlyCondition) {\r\n      return f.readonlyCondition(this.data);\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  @ContentChild('dynamicSelect') dynamicSelectTemplate: TemplateRef<any>;\r\n  fileNames\r\n  fileField: Field;\r\n  fileViewField: Field;\r\n  @Input() files: any[] = [];\r\n  fields: Field[];\r\n  buttonDisplay = \"Submit\";\r\n  isProcessing : boolean = false;\r\n  multiColumn : boolean = false;\r\n\r\n  childFields : Field[];\r\n\r\n  @Input() data: any;\r\n  @Input() config: FormConfig;\r\n  @Output() buttonClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  selectChanged(field: Field){\r\n    this.inputChanged(field, this.data[field.name] )\r\n  }\r\n\r\n  inputChanged(field : Field, value){\r\n\r\n\r\n    this.inputChange.emit({ field: field, value: value})\r\n\r\n    this.updateChildOptions(field.name)\r\n\r\n    if (this.config.mode == 'create' && field.child){\r\n\r\n      let child = this.fields.find(x => x.name == field.child.childField)\r\n      this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[field.child.childValueField]\r\n\r\n    }\r\n\r\n\r\n    if (this.config.mode == 'create' && field.children){\r\n      console.log(\"Children found\")\r\n\r\n      field.children.forEach(childConfig => {\r\n\r\n        let child = this.fields.find(x => x.name == childConfig.childField)\r\n        console.log(\"Child found\")\r\n\r\n        this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[childConfig.childValueField]\r\n\r\n      });\r\n\r\n    }\r\n\r\n  }\r\n\r\n  updateChildOptions(masterFieldName: string){\r\n\r\n    let child = this.childFields.find(x => x.masterField == masterFieldName)\r\n    if (child != null) {\r\n\r\n      //current is master\r\n\r\n\r\n      if (child.masterOptions){\r\n        child.options = child.masterOptions.filter(x => x[child.masterOptionValue] == this.data[masterFieldName])\r\n      }else{\r\n        console.log(\"Master Options not found\")\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private loadChildMasterOptions(child: Field) {\r\n    if (!child.loadAction) return;\r\n\r\n    this.dataService.CallApi(child.loadAction).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        child.masterOptions = apiResponse.data;\r\n        this.updateChildOptions(child.masterField);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  buttonClicked(){\r\n\r\n    this.buttonClick.emit(this.data);\r\n\r\n    let button = this.config.button;\r\n\r\n    if (!button) {\r\n      return;\r\n    }\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.getVisibleFields(),this.data);\r\n    if (resp != ''){\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n\r\n\r\n    if (button.confirm){\r\n\r\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.processCall(button)\r\n        }\r\n      });\r\n\r\n    }else{\r\n      this.processCall(button)\r\n    }\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n  processCall(button: Button){\r\n\r\n    if (!button.action) return\r\n\r\n    let dataOut;\r\n\r\n    if (button.action.isFormData){\r\n\r\n      let formData: FormData = new FormData();\r\n      for (let i = 0; i < this.files.length; i++) {\r\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\r\n      }\r\n\r\n      formData.append(\"data\", JSON.stringify(this.data));\r\n\r\n\r\n      dataOut = formData\r\n    }else{\r\n\r\n      dataOut = this.data\r\n    }\r\n\r\n\r\n\r\n\r\n    this.isProcessing = true\r\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\r\n      this.isProcessing = false\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Submitted\");\r\n        }\r\n\r\n        if (this.config.reset) {\r\n          Core.resetObject(this.fields, this.data)\r\n          this.files = [];\r\n        }\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  processForm(){\r\n\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\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  >\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]=\"field.loadAction\" [path]=\"field.path\" [folderName]=\"data[field.keyField]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}}</label>\r\n\r\n        <spa-label *ngSwitchCase=\"'label'\" [display]=\"field.alias ?? field.name | camelToWords\" [value]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [format]=\"field.format ?? 'text'\" ></spa-label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></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]=\"testReadOnly(field)\" [infoMessage]=\"field.infoMessage\" ></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></spa-date>\r\n\r\n        <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [min]=\"field.min\" [max]=\"field.max\" [infoMessage]=\"field.infoMessage\" ></spa-datetime>\r\n\r\n        <spa-email *ngSwitchCase=\"'email'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-email>\r\n\r\n        <spa-text *ngSwitchCase=\"'password'\" [format]=\"'password'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [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]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-text>\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'select'\">\r\n          <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                  $implicit: field,\r\n                  field: field,\r\n                  data: data,\r\n                  testReadOnly: testReadOnly.bind(this),\r\n                  selectChanged: selectChanged.bind(this)\r\n                }\">\r\n          </ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <spa-multi-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\">\r\n        </spa-multi-select>\r\n\r\n        <spa-multi-text *ngSwitchCase=\"'multi-text'\" [strict]=\"field.strict\" [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])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-multi-text>\r\n\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'composite'\">\r\n          <div class=\"composite-field-container\">\r\n            <div class=\"composite-field-group\">\r\n              <ng-container *ngFor=\"let subfield of getVisibleSubfields(field)\">\r\n                <ng-container [ngSwitch]=\"subfield.type\">\r\n\r\n                  <spa-number *ngSwitchCase=\"'number'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\"></spa-number>\r\n\r\n                  <spa-money *ngSwitchCase=\"'money'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-money>\r\n\r\n                  <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [infoMessage]=\"subfield.infoMessage\" ></spa-check>\r\n\r\n                  <spa-date *ngSwitchCase=\"'date'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-date>\r\n\r\n                  <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [infoMessage]=\"subfield.infoMessage\" ></spa-datetime>\r\n\r\n                  <ng-container *ngSwitchCase=\"'select'\">\r\n                    <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                                    $implicit: field,\r\n                                    field: field,\r\n                                    data: data,\r\n                                    testReadOnly: testReadOnly.bind(this),\r\n                                    selectChanged: selectChanged.bind(this)\r\n                                  }\">\r\n                    </ng-container>\r\n                  </ng-container>\r\n\r\n                  <spa-text *ngSwitchDefault [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\"  [options]=\"subfield.options\" [optionDisplay]=\"subfield.optionDisplay ?? 'name'\" [optionValue]=\"subfield.optionValue ?? 'value'\" [rows]=\"subfield.rows\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\" [loadAction]=\"subfield.loadAction\"></spa-text>\r\n\r\n\r\n                </ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [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]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></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"]}
|
|
@@ -21,7 +21,7 @@ export class SelectComponent extends SelectCommonComponent {
|
|
|
21
21
|
this.isHovered = isHovered;
|
|
22
22
|
}
|
|
23
23
|
canCreate() {
|
|
24
|
-
if (!this.detailsConfig
|
|
24
|
+
if (!this.detailsConfig?.buttons)
|
|
25
25
|
return false;
|
|
26
26
|
const createButton = this.detailsConfig.buttons.find(b => b.name === 'create');
|
|
27
27
|
return createButton && (!createButton.disabled || !createButton.disabled(this.value));
|
|
@@ -46,11 +46,11 @@ export class SelectComponent extends SelectCommonComponent {
|
|
|
46
46
|
}
|
|
47
47
|
}
|
|
48
48
|
SelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectComponent, deps: [{ token: i1.MessageService }, { token: i2.DataServiceLib }, { token: i3.DialogService }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
-
SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectComponent, selector: "spa-select", inputs: { detailsConfig: "detailsConfig" }, usesInheritance: true, ngImport: i0, template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered
|
|
49
|
+
SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectComponent, selector: "spa-select", inputs: { detailsConfig: "detailsConfig" }, usesInheritance: true, ngImport: i0, template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [field]=\"field\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n <mat-icon style=\"color: green;\">add</mat-icon>\r\n </button>\r\n <button mat-icon-button *ngIf=\"detailsConfig && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">launch</mat-icon>\r\n </button>\r\n\r\n </ng-container>\r\n</spa-select-common>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.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: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i8.SelectCommonComponent, selector: "spa-select-common", inputs: ["width", "readonly", "required", "defaultFirstValue", "readonlyMode", "hint", "placeholder", "multiple", "display", "value", "options", "masterOptions", "masterField", "optionValue", "optionDisplay", "optionDisplayExtra", "nullable", "infoMessage", "copyContent", "loadAction", "field"], outputs: ["valueChange", "hoverChange"] }] });
|
|
50
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectComponent, decorators: [{
|
|
51
51
|
type: Component,
|
|
52
|
-
args: [{ selector: 'spa-select', template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered
|
|
52
|
+
args: [{ selector: 'spa-select', template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [field]=\"field\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n <mat-icon style=\"color: green;\">add</mat-icon>\r\n </button>\r\n <button mat-icon-button *ngIf=\"detailsConfig && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">launch</mat-icon>\r\n </button>\r\n\r\n </ng-container>\r\n</spa-select-common>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"] }]
|
|
53
53
|
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }]; }, propDecorators: { detailsConfig: [{
|
|
54
54
|
type: Input
|
|
55
55
|
}] } });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0L3NlbGVjdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixLQUFLLEVBQWtCLE1BQU0sZUFBZSxDQUFDO0FBSS9FLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDOzs7Ozs7Ozs7O0FBUTNGLE1BQU0sT0FBTyxlQUFnQixTQUFRLHFCQUFxQjtJQUV4RCxZQUNxQixjQUE4QixFQUFxQixXQUEyQixFQUN6RixhQUE0QjtRQUdwQyxLQUFLLENBQUMsY0FBYyxFQUFDLFdBQVcsQ0FBQyxDQUFDO1FBSmYsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQXFCLGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtRQUN6RixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtJQUl0QyxDQUFDO0lBTUQsYUFBYSxDQUFDLFNBQWtCO1FBQzlCLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQzdCLENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsT0FBTztZQUFFLE9BQU8sS0FBSyxDQUFDO1FBQy9DLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssUUFBUSxDQUFDLENBQUM7UUFDL0UsT0FBTyxZQUFZLElBQUksQ0FBQyxDQUFDLFlBQVksQ0FBQyxRQUFRLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBaUIsRUFBRSxJQUF1QjtRQUNwRCxLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RCLE1BQU0sV0FBVyxHQUFHLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBRzVGLElBQUksSUFBSSxLQUFLLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssTUFBTSxDQUFDLEVBQUU7Z0JBQy9FLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7YUFDakU7WUFFRCxJQUFJLENBQUMsYUFBYSxDQUFDLDJCQUEyQixDQUM1QyxJQUFJLEVBQ0osV0FBVyxFQUNYLElBQUksQ0FBQyxhQUFhLEVBQ2xCLHFCQUFxQixDQUN0QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFFcEIsSUFBSSxNQUFNLENBQUMsT0FBTyxLQUFLLFNBQVMsRUFBQztvQkFDL0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztpQkFDckI7WUFFSCxDQUFDLENBQUMsQ0FBQztTQUVKO2FBQU07WUFDTCxJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1NBQ3ZEO0lBQ0gsQ0FBQzs7NEdBcERVLGVBQWU7Z0dBQWYsZUFBZSxxSENiNUIsKzJDQWlCQTsyRkRKYSxlQUFlO2tCQUwzQixTQUFTOytCQUNFLFlBQVk7OEpBY2IsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgIEFjdGlvbiwgQXBpUmVzcG9uc2UsIEJ1dHRvbiwgRGV0YWlsc0RpYWxvZ0NvbmZpZyB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XHJcbmltcG9ydCB7IE1lc3NhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbWVzc2FnZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGlhbG9nU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2RpYWxvZy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU2VsZWN0Q29tbW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vc2VsZWN0LWNvbW1vbi9zZWxlY3QtY29tbW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERldGFpbHNEaWFsb2dJbnRlcm5hbCB9IGZyb20gJy4uL3RhYmxlLWludGVybmFsL2RldGFpbHNEaWFsb2ctaW50ZXJuYWwuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRGF0YVNlcnZpY2VMaWIgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9kYXRhbGliLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtc2VsZWN0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zZWxlY3QuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RDb21wb25lbnQgZXh0ZW5kcyBTZWxlY3RDb21tb25Db21wb25lbnQge1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBtZXNzYWdlU2VydmljZTogTWVzc2FnZVNlcnZpY2UsIHByb3RlY3RlZCBvdmVycmlkZSBkYXRhU2VydmljZTogRGF0YVNlcnZpY2VMaWIsXHJcbiAgICBwcml2YXRlIGRpYWxvZ1NlcnZpY2U6IERpYWxvZ1NlcnZpY2UsXHJcblxyXG4gICkge1xyXG4gICAgc3VwZXIobWVzc2FnZVNlcnZpY2UsZGF0YVNlcnZpY2UpO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KCkgZGV0YWlsc0NvbmZpZzogRGV0YWlsc0RpYWxvZ0NvbmZpZztcclxuXHJcblxyXG5cclxuICBvbkhvdmVyQ2hhbmdlKGlzSG92ZXJlZDogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgdGhpcy5pc0hvdmVyZWQgPSBpc0hvdmVyZWQ7XHJcbiAgfVxyXG5cclxuICBjYW5DcmVhdGUoKTogYm9vbGVhbiB7XHJcbiAgICBpZiAoIXRoaXMuZGV0YWlsc0NvbmZpZz8uYnV0dG9ucykgcmV0dXJuIGZhbHNlO1xyXG4gICAgY29uc3QgY3JlYXRlQnV0dG9uID0gdGhpcy5kZXRhaWxzQ29uZmlnLmJ1dHRvbnMuZmluZChiID0+IGIubmFtZSA9PT0gJ2NyZWF0ZScpO1xyXG4gICAgcmV0dXJuIGNyZWF0ZUJ1dHRvbiAmJiAoIWNyZWF0ZUJ1dHRvbi5kaXNhYmxlZCB8fCAhY3JlYXRlQnV0dG9uLmRpc2FibGVkKHRoaXMudmFsdWUpKTtcclxuICB9XHJcblxyXG4gIG9uUGVla0NsaWNrKGV2ZW50OiBNb3VzZUV2ZW50LCBtb2RlOiAnY3JlYXRlJyB8ICd2aWV3Jyk6IHZvaWQge1xyXG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XHJcblxyXG4gICAgaWYgKHRoaXMuZGV0YWlsc0NvbmZpZykge1xyXG4gICAgICBjb25zdCBkeW5hbWljRGF0YSA9IG1vZGUgPT09ICdjcmVhdGUnID8ge30gOiB7IFt0aGlzLmRldGFpbHNDb25maWcuaGVyb0ZpZWxkXTogdGhpcy52YWx1ZSB9O1xyXG5cclxuXHJcbiAgICAgIGlmIChtb2RlID09PSAndmlldycgJiYgIXRoaXMuZGV0YWlsc0NvbmZpZy5idXR0b25zLnNvbWUoYiA9PiBiLm5hbWUgPT09ICd2aWV3JykpIHtcclxuICAgICAgICB0aGlzLmRldGFpbHNDb25maWcuYnV0dG9ucy5wdXNoKHsgbmFtZTogJ3ZpZXcnLCBkaWFsb2c6IHRydWUgfSk7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIHRoaXMuZGlhbG9nU2VydmljZS5vcGVuQ29uZmlndXJlZERldGFpbHNEaWFsb2coXHJcbiAgICAgICAgbW9kZSxcclxuICAgICAgICBkeW5hbWljRGF0YSxcclxuICAgICAgICB0aGlzLmRldGFpbHNDb25maWcsXHJcbiAgICAgICAgRGV0YWlsc0RpYWxvZ0ludGVybmFsXHJcbiAgICAgICkuc3Vic2NyaWJlKHJlc3VsdCA9PiB7XHJcbiAgICAgICAgY29uc29sZS5sb2cocmVzdWx0KTtcclxuXHJcbiAgICAgICAgaWYgKHJlc3VsdC5tZXNzYWdlID09PSAnc3VjY2Vzcycpe1xyXG4gICAgICAgICAgdGhpcy5yZWZyZXNoKGV2ZW50KTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICB9KTtcclxuXHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLm1lc3NhZ2VTZXJ2aWNlLnRvYXN0KFwiUGVlayBjb25maWd1cmF0aW9uIGVycm9yXCIpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcblxyXG5cclxufVxyXG5cclxuIiwiPHNwYS1zZWxlY3QtY29tbW9uIFt3aWR0aF09XCJ3aWR0aFwiIFtyZWFkb25seV09XCJyZWFkb25seVwiIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiIFtkZWZhdWx0Rmlyc3RWYWx1ZV09XCJkZWZhdWx0Rmlyc3RWYWx1ZVwiXHJcbiAgICAgICAgICAgICAgICAgICBbcmVhZG9ubHlNb2RlXT1cInJlYWRvbmx5TW9kZVwiIFtoaW50XT1cImhpbnRcIiBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIiBbbXVsdGlwbGVdPVwibXVsdGlwbGVcIlxyXG4gICAgICAgICAgICAgICAgICAgW2Rpc3BsYXldPVwiZGlzcGxheVwiIFsodmFsdWUpXT1cInZhbHVlXCIgW29wdGlvbnNdPVwib3B0aW9uc1wiIFttYXN0ZXJPcHRpb25zXT1cIm1hc3Rlck9wdGlvbnNcIiBbbWFzdGVyRmllbGRdPVwibWFzdGVyRmllbGRcIlxyXG4gICAgICAgICAgICAgICAgICAgW29wdGlvblZhbHVlXT1cIm9wdGlvblZhbHVlXCIgW29wdGlvbkRpc3BsYXldPVwib3B0aW9uRGlzcGxheVwiIFtvcHRpb25EaXNwbGF5RXh0cmFdPVwib3B0aW9uRGlzcGxheUV4dHJhXCJcclxuICAgICAgICAgICAgICAgICAgIFtudWxsYWJsZV09XCJudWxsYWJsZVwiIFtpbmZvTWVzc2FnZV09XCJpbmZvTWVzc2FnZVwiIFtjb3B5Q29udGVudF09XCJjb3B5Q29udGVudFwiIFtsb2FkQWN0aW9uXT1cImxvYWRBY3Rpb25cIiBbZmllbGRdPVwiZmllbGRcIlxyXG4gICAgICAgICAgICAgICAgICAgKHZhbHVlQ2hhbmdlKT1cInZhbHVlQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAgICAoaG92ZXJDaGFuZ2UpPVwib25Ib3ZlckNoYW5nZSgkZXZlbnQpXCI+XHJcbiAgPG5nLWNvbnRhaW5lciBhZGRpdGlvbmFsQnV0dG9ucz5cclxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uICpuZ0lmPVwiZGV0YWlsc0NvbmZpZyAmJiBjYW5DcmVhdGUoKSAmJiBpc0hvdmVyZWRcIiAoY2xpY2spPVwib25QZWVrQ2xpY2soJGV2ZW50LCAnY3JlYXRlJylcIiBtYXRUb29sdGlwPVwiQWRkXCIgbWF0VG9vbHRpcFBvc2l0aW9uPVwiYWJvdmVcIj5cclxuICAgICAgPG1hdC1pY29uIHN0eWxlPVwiY29sb3I6IGdyZWVuO1wiPmFkZDwvbWF0LWljb24+XHJcbiAgICA8L2J1dHRvbj5cclxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uICpuZ0lmPVwiZGV0YWlsc0NvbmZpZyAmJiBpc0hvdmVyZWQgJiYgdmFsdWVcIiAoY2xpY2spPVwib25QZWVrQ2xpY2soJGV2ZW50LCAndmlldycpXCIgbWF0VG9vbHRpcD1cIlZpZXdcIiBtYXRUb29sdGlwUG9zaXRpb249XCJhYm92ZVwiPlxyXG4gICAgICA8bWF0LWljb24gY29sb3I9XCJwcmltYXJ5XCI+bGF1bmNoPC9tYXQtaWNvbj5cclxuICAgIDwvYnV0dG9uPlxyXG5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9zcGEtc2VsZWN0LWNvbW1vbj5cclxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "../../services/message.service";
|
|
4
5
|
import * as i2 from "../../services/datalib.service";
|
|
@@ -43,6 +44,14 @@ export class SelectCommonComponent {
|
|
|
43
44
|
this.value = this.options[0][this.optionValue];
|
|
44
45
|
this.changed();
|
|
45
46
|
}
|
|
47
|
+
if (this.field?.optionsSubject) {
|
|
48
|
+
this.subscription = this.field.optionsSubject.subscribe(newOptions => {
|
|
49
|
+
if (newOptions) {
|
|
50
|
+
this.options = newOptions;
|
|
51
|
+
// this.initFilter();
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
46
55
|
}
|
|
47
56
|
ngOnChanges() {
|
|
48
57
|
if (this.readonlyMode != "" && this.options.length > 0) {
|
|
@@ -83,12 +92,26 @@ export class SelectCommonComponent {
|
|
|
83
92
|
this.dataService.CallApi(loadAction, "").subscribe((apiResponse) => {
|
|
84
93
|
if (apiResponse.success) {
|
|
85
94
|
this.options = apiResponse.data;
|
|
95
|
+
if (this.field) {
|
|
96
|
+
this.field.options = apiResponse.data;
|
|
97
|
+
if (!this.field.optionsSubject) {
|
|
98
|
+
this.field.optionsSubject = new BehaviorSubject(apiResponse.data);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.field.optionsSubject.next(apiResponse.data);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
86
104
|
}
|
|
87
105
|
});
|
|
88
106
|
}
|
|
107
|
+
ngOnDestroy() {
|
|
108
|
+
if (this.subscription) {
|
|
109
|
+
this.subscription.unsubscribe();
|
|
110
|
+
}
|
|
111
|
+
}
|
|
89
112
|
}
|
|
90
113
|
SelectCommonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectCommonComponent, deps: [{ token: i1.MessageService }, { token: i2.DataServiceLib }], target: i0.ɵɵFactoryTarget.Component });
|
|
91
|
-
SelectCommonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectCommonComponent, selector: "spa-select-common", inputs: { width: "width", readonly: "readonly", required: "required", defaultFirstValue: "defaultFirstValue", readonlyMode: "readonlyMode", hint: "hint", placeholder: "placeholder", multiple: "multiple", display: "display", value: "value", options: "options", masterOptions: "masterOptions", masterField: "masterField", optionValue: "optionValue", optionDisplay: "optionDisplay", optionDisplayExtra: "optionDisplayExtra", nullable: "nullable", infoMessage: "infoMessage", copyContent: "copyContent", loadAction: "loadAction" }, outputs: { valueChange: "valueChange", hoverChange: "hoverChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n <mat-label>{{display}}</mat-label>\r\n <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n </mat-option>\r\n </mat-select>\r\n\r\n <div matSuffix class=\"suffix-icons\">\r\n <ng-content select=\"[additionalButtons]\"></ng-content>\r\n <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">cached</mat-icon>\r\n </button>\r\n <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n </div>\r\n\r\n</mat-form-field>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"], dependencies: [{ 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.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix]" }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i10.SuffixComponent, selector: "spa-suffix", inputs: ["label", "infoMessage", "copyContent", "isHovered", "clearContent", "value"], outputs: ["infoClick", "copyClick", "clearClick", "valueChange"] }] });
|
|
114
|
+
SelectCommonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectCommonComponent, selector: "spa-select-common", inputs: { width: "width", readonly: "readonly", required: "required", defaultFirstValue: "defaultFirstValue", readonlyMode: "readonlyMode", hint: "hint", placeholder: "placeholder", multiple: "multiple", display: "display", value: "value", options: "options", masterOptions: "masterOptions", masterField: "masterField", optionValue: "optionValue", optionDisplay: "optionDisplay", optionDisplayExtra: "optionDisplayExtra", nullable: "nullable", infoMessage: "infoMessage", copyContent: "copyContent", loadAction: "loadAction", field: "field" }, outputs: { valueChange: "valueChange", hoverChange: "hoverChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n <mat-label>{{display}}</mat-label>\r\n <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n </mat-option>\r\n </mat-select>\r\n\r\n <div matSuffix class=\"suffix-icons\">\r\n <ng-content select=\"[additionalButtons]\"></ng-content>\r\n <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">cached</mat-icon>\r\n </button>\r\n <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n </div>\r\n\r\n</mat-form-field>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"], dependencies: [{ 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.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix]" }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i10.SuffixComponent, selector: "spa-suffix", inputs: ["label", "infoMessage", "copyContent", "isHovered", "clearContent", "value"], outputs: ["infoClick", "copyClick", "clearClick", "valueChange"] }] });
|
|
92
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectCommonComponent, decorators: [{
|
|
93
116
|
type: Component,
|
|
94
117
|
args: [{ selector: 'spa-select-common', template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n <mat-label>{{display}}</mat-label>\r\n <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n </mat-option>\r\n </mat-select>\r\n\r\n <div matSuffix class=\"suffix-icons\">\r\n <ng-content select=\"[additionalButtons]\"></ng-content>\r\n <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">cached</mat-icon>\r\n </button>\r\n <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n </div>\r\n\r\n</mat-form-field>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"] }]
|
|
@@ -132,9 +155,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
132
155
|
type: Input
|
|
133
156
|
}], loadAction: [{
|
|
134
157
|
type: Input
|
|
158
|
+
}], field: [{
|
|
159
|
+
type: Input
|
|
135
160
|
}], valueChange: [{
|
|
136
161
|
type: Output
|
|
137
162
|
}], hoverChange: [{
|
|
138
163
|
type: Output
|
|
139
164
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-common.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Action, ApiResponse } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\n\r\n@Component({\r\n  selector: 'spa-select-common',\r\n  templateUrl: './select-common.component.html',\r\n  styleUrls: ['./select-common.component.css']\r\n})\r\nexport class SelectCommonComponent implements OnInit {\r\n\r\n  constructor(protected messageService: MessageService, protected dataService: DataServiceLib,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.placeholder == \"\") {\r\n      this.placeholder = \"Select \" + this.display;\r\n    }\r\n\r\n    if(this.options == null || this.options == undefined || this.options.length == 0){\r\n      this.getData(this.loadAction);\r\n    }\r\n\r\n\r\n    if (this.defaultFirstValue && this.options && this.options.length > 0 && (this.value == null || this.value == undefined || (typeof (this.value) == 'string' && this.value == '') || (typeof (this.value) == 'number' && this.value == 0))) {\r\n      this.value = this.options[0][this.optionValue]\r\n      this.changed();\r\n    }\r\n\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (this.readonlyMode != \"\" && this.options.length > 0) {\r\n      this.displayValue = this.options.filter((m) => m[`${this.optionValue}`] == this.value)[0][`${this.optionDisplay}`]\r\n    }\r\n\r\n    //add a null option\r\n    if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {\r\n      this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: \"None\" })\r\n    }\r\n\r\n  }\r\n\r\n  displayValue;\r\n  isHovered = false;\r\n\r\n  @Input() width = \"100%\"\r\n  @Input() readonly = false;\r\n  @Input() required = true;\r\n  @Input() defaultFirstValue = false;\r\n  @Input() readonlyMode = \"\";\r\n  @Input() hint = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() multiple: boolean = false;\r\n\r\n  @Input() display = \"\";\r\n  @Input() value;\r\n  @Input() options: any;\r\n  @Input() masterOptions: any;\r\n  @Input() masterField: string;\r\n  @Input() optionValue = \"\";\r\n  @Input() optionDisplay = \"\";\r\n  @Input() optionDisplayExtra = \"\";\r\n  @Input() nullable = false;\r\n\r\n\r\n  @Input() infoMessage: string;\r\n  @Input() copyContent = false;\r\n  @Input() loadAction: Action;\r\n\r\n  @Output() valueChange = new EventEmitter();\r\n  @Output() hoverChange = new EventEmitter<boolean>();\r\n\r\n  changed() {\r\n    this.valueChange.emit(this.value);\r\n  }\r\n\r\n  onMouseEnter(): void {\r\n    this.isHovered = true;\r\n    this.hoverChange.emit(true);\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    this.isHovered = false;\r\n    this.hoverChange.emit(false);\r\n  }\r\n\r\n  refresh(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    if (!this.loadAction) {\r\n      return;\r\n    }\r\n\r\n    const refreshAction = {\r\n      ...this.loadAction,\r\n      forceRefresh: true\r\n    };\r\n\r\n    this.getData(refreshAction);\r\n  }\r\n\r\n  getData(loadAction: Action) {\r\n\r\n    if (!loadAction) return;\r\n    if (this.masterField) return; //if master field is set, then it will be loaded by the master field\r\n    this.dataService.CallApi(loadAction, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n        this.options = apiResponse.data;\r\n      }\r\n    });\r\n  }\r\n\r\n}\r\n","<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n  <mat-label>{{display}}</mat-label>\r\n  <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n    <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n      {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <div matSuffix class=\"suffix-icons\">\r\n    <ng-content select=\"[additionalButtons]\"></ng-content>\r\n    <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">cached</mat-icon>\r\n    </button>\r\n    <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n  </div>\r\n\r\n</mat-form-field>\r\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-common.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Action, ApiResponse, Field } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-select-common',\r\n  templateUrl: './select-common.component.html',\r\n  styleUrls: ['./select-common.component.css']\r\n})\r\nexport class SelectCommonComponent implements OnInit, OnDestroy {\r\n\r\n  constructor(protected messageService: MessageService, protected dataService: DataServiceLib,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.placeholder == \"\") {\r\n      this.placeholder = \"Select \" + this.display;\r\n    }\r\n\r\n    if(this.options == null || this.options == undefined || this.options.length == 0){\r\n      this.getData(this.loadAction);\r\n    }\r\n\r\n\r\n    if (this.defaultFirstValue && this.options && this.options.length > 0 && (this.value == null || this.value == undefined || (typeof (this.value) == 'string' && this.value == '') || (typeof (this.value) == 'number' && this.value == 0))) {\r\n      this.value = this.options[0][this.optionValue]\r\n      this.changed();\r\n    }\r\n\r\n    if (this.field?.optionsSubject) {\r\n      this.subscription = this.field.optionsSubject.subscribe(newOptions => {\r\n        if (newOptions) {\r\n          this.options = newOptions;\r\n          // this.initFilter();\r\n        }\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (this.readonlyMode != \"\" && this.options.length > 0) {\r\n      this.displayValue = this.options.filter((m) => m[`${this.optionValue}`] == this.value)[0][`${this.optionDisplay}`]\r\n    }\r\n\r\n    //add a null option\r\n    if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {\r\n      this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: \"None\" })\r\n    }\r\n\r\n  }\r\n\r\n  displayValue;\r\n  isHovered = false;\r\n\r\n  private subscription: Subscription;\r\n\r\n\r\n  @Input() width = \"100%\"\r\n  @Input() readonly = false;\r\n  @Input() required = true;\r\n  @Input() defaultFirstValue = false;\r\n  @Input() readonlyMode = \"\";\r\n  @Input() hint = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() multiple: boolean = false;\r\n\r\n  @Input() display = \"\";\r\n  @Input() value;\r\n  @Input() options: any;\r\n  @Input() masterOptions: any;\r\n  @Input() masterField: string;\r\n  @Input() optionValue = \"\";\r\n  @Input() optionDisplay = \"\";\r\n  @Input() optionDisplayExtra = \"\";\r\n  @Input() nullable = false;\r\n\r\n\r\n  @Input() infoMessage: string;\r\n  @Input() copyContent = false;\r\n  @Input() loadAction: Action;\r\n  @Input() field: Field;\r\n\r\n  @Output() valueChange = new EventEmitter();\r\n  @Output() hoverChange = new EventEmitter<boolean>();\r\n\r\n  changed() {\r\n    this.valueChange.emit(this.value);\r\n  }\r\n\r\n  onMouseEnter(): void {\r\n    this.isHovered = true;\r\n    this.hoverChange.emit(true);\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    this.isHovered = false;\r\n    this.hoverChange.emit(false);\r\n  }\r\n\r\n  refresh(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    if (!this.loadAction) {\r\n      return;\r\n    }\r\n\r\n    const refreshAction = {\r\n      ...this.loadAction,\r\n      forceRefresh: true\r\n    };\r\n\r\n    this.getData(refreshAction);\r\n  }\r\n\r\n  getData(loadAction: Action) {\r\n\r\n    if (!loadAction) return;\r\n    if (this.masterField) return; //if master field is set, then it will be loaded by the master field\r\n    this.dataService.CallApi(loadAction, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n        this.options = apiResponse.data;\r\n\r\n        if (this.field) {\r\n          this.field.options = apiResponse.data;\r\n\r\n          if (!this.field.optionsSubject) {\r\n            this.field.optionsSubject = new BehaviorSubject(apiResponse.data);\r\n          } else {\r\n            this.field.optionsSubject.next(apiResponse.data);\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n}\r\n","<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n  <mat-label>{{display}}</mat-label>\r\n  <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n    <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n      {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <div matSuffix class=\"suffix-icons\">\r\n    <ng-content select=\"[additionalButtons]\"></ng-content>\r\n    <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">cached</mat-icon>\r\n    </button>\r\n    <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n  </div>\r\n\r\n</mat-form-field>\r\n"]}
|
|
@@ -21,7 +21,7 @@ export class SelectInternalComponent extends SelectCommonComponent {
|
|
|
21
21
|
this.isHovered = isHovered;
|
|
22
22
|
}
|
|
23
23
|
canCreate() {
|
|
24
|
-
if (!this.detailsConfig
|
|
24
|
+
if (!this.detailsConfig?.buttons)
|
|
25
25
|
return false;
|
|
26
26
|
const createButton = this.detailsConfig.buttons.find(b => b.name === 'create');
|
|
27
27
|
return createButton && (!createButton.disabled || !createButton.disabled(this.value));
|
|
@@ -46,11 +46,11 @@ export class SelectInternalComponent extends SelectCommonComponent {
|
|
|
46
46
|
}
|
|
47
47
|
}
|
|
48
48
|
SelectInternalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectInternalComponent, deps: [{ token: i1.MessageService }, { token: i2.DataServiceLib }, { token: i3.DialogService }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
-
SelectInternalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectInternalComponent, selector: "spa-select-internal", inputs: { detailsConfig: "detailsConfig" }, usesInheritance: true, ngImport: i0, template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered
|
|
49
|
+
SelectInternalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectInternalComponent, selector: "spa-select-internal", inputs: { detailsConfig: "detailsConfig" }, usesInheritance: true, ngImport: i0, template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [field]=\"field\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n <mat-icon style=\"color: green;\">add</mat-icon>\r\n </button>\r\n <button mat-icon-button *ngIf=\"detailsConfig && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">launch</mat-icon>\r\n </button>\r\n\r\n </ng-container>\r\n</spa-select-common>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.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: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i8.SelectCommonComponent, selector: "spa-select-common", inputs: ["width", "readonly", "required", "defaultFirstValue", "readonlyMode", "hint", "placeholder", "multiple", "display", "value", "options", "masterOptions", "masterField", "optionValue", "optionDisplay", "optionDisplayExtra", "nullable", "infoMessage", "copyContent", "loadAction", "field"], outputs: ["valueChange", "hoverChange"] }] });
|
|
50
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectInternalComponent, decorators: [{
|
|
51
51
|
type: Component,
|
|
52
|
-
args: [{ selector: 'spa-select-internal', template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered
|
|
52
|
+
args: [{ selector: 'spa-select-internal', template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [field]=\"field\"\r\n (valueChange)=\"valueChange.emit($event)\"\r\n (hoverChange)=\"onHoverChange($event)\">\r\n <ng-container additionalButtons>\r\n <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n <mat-icon style=\"color: green;\">add</mat-icon>\r\n </button>\r\n <button mat-icon-button *ngIf=\"detailsConfig && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">launch</mat-icon>\r\n </button>\r\n\r\n </ng-container>\r\n</spa-select-common>\r\n" }]
|
|
53
53
|
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }]; }, propDecorators: { detailsConfig: [{
|
|
54
54
|
type: Input
|
|
55
55
|
}] } });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWludGVybmFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3NlbGVjdC1pbnRlcm5hbC9zZWxlY3QtaW50ZXJuYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0LWludGVybmFsL3NlbGVjdC1pbnRlcm5hbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixLQUFLLEVBQWtCLE1BQU0sZUFBZSxDQUFDO0FBSS9FLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRWpGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOzs7Ozs7Ozs7O0FBTy9FLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxxQkFBcUI7SUFDaEUsWUFDcUIsY0FBOEIsRUFBcUIsV0FBMkIsRUFDekYsYUFBNEI7UUFHcEMsS0FBSyxDQUFDLGNBQWMsRUFBRSxXQUFXLENBQUMsQ0FBQztRQUpoQixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFBcUIsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBQ3pGLGtCQUFhLEdBQWIsYUFBYSxDQUFlO0lBSXRDLENBQUM7SUFNRCxhQUFhLENBQUMsU0FBa0I7UUFDOUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDN0IsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxPQUFPO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDL0MsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQztRQUMvRSxPQUFPLFlBQVksSUFBSSxDQUFDLENBQUMsWUFBWSxDQUFDLFFBQVEsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDeEYsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFpQixFQUFFLElBQXVCO1FBQ3BELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUV4QixJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDdEIsTUFBTSxXQUFXLEdBQUcsSUFBSSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFHNUYsSUFBSSxJQUFJLEtBQUssTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxNQUFNLENBQUMsRUFBRTtnQkFDL0UsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQzthQUNqRTtZQUVELElBQUksQ0FBQyxhQUFhLENBQUMsMkJBQTJCLENBQzVDLElBQUksRUFDSixXQUFXLEVBQ1gsSUFBSSxDQUFDLGFBQWEsRUFDbEIsaUJBQWlCLENBQ2xCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFO2dCQUNuQixPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO2dCQUVwQixJQUFJLE1BQU0sQ0FBQyxPQUFPLEtBQUssU0FBUyxFQUFFO29CQUNoQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUNyQjtZQUVILENBQUMsQ0FBQyxDQUFDO1NBRUo7YUFBTTtZQUNMLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7U0FDdkQ7SUFDSCxDQUFDOztvSEFuRFUsdUJBQXVCO3dHQUF2Qix1QkFBdUIsOEhDYnBDLCsyQ0FpQkE7MkZESmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHFCQUFxQjs4SkFhdEIsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aW9uLCBBcGlSZXNwb25zZSwgRGV0YWlsc0RpYWxvZ0NvbmZpZyB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XHJcbmltcG9ydCB7IE1lc3NhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbWVzc2FnZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGlhbG9nU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2RpYWxvZy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU2VsZWN0Q29tbW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vc2VsZWN0LWNvbW1vbi9zZWxlY3QtY29tbW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGFTZXJ2aWNlTGliIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZGF0YWxpYi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGV0YWlsc0RpYWxvZ0xpdGUgfSBmcm9tICcuLi90YWJsZS1saXRlL2RldGFpbHNEaWFsb2ctbGl0ZS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtc2VsZWN0LWludGVybmFsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LWludGVybmFsLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zZWxlY3QtaW50ZXJuYWwuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RJbnRlcm5hbENvbXBvbmVudCBleHRlbmRzIFNlbGVjdENvbW1vbkNvbXBvbmVudCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgbWVzc2FnZVNlcnZpY2U6IE1lc3NhZ2VTZXJ2aWNlLCBwcm90ZWN0ZWQgb3ZlcnJpZGUgZGF0YVNlcnZpY2U6IERhdGFTZXJ2aWNlTGliLFxyXG4gICAgcHJpdmF0ZSBkaWFsb2dTZXJ2aWNlOiBEaWFsb2dTZXJ2aWNlLFxyXG5cclxuICApIHtcclxuICAgIHN1cGVyKG1lc3NhZ2VTZXJ2aWNlLCBkYXRhU2VydmljZSk7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKSBkZXRhaWxzQ29uZmlnOiBEZXRhaWxzRGlhbG9nQ29uZmlnO1xyXG5cclxuXHJcblxyXG4gIG9uSG92ZXJDaGFuZ2UoaXNIb3ZlcmVkOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICB0aGlzLmlzSG92ZXJlZCA9IGlzSG92ZXJlZDtcclxuICB9XHJcblxyXG4gIGNhbkNyZWF0ZSgpOiBib29sZWFuIHtcclxuICAgIGlmICghdGhpcy5kZXRhaWxzQ29uZmlnPy5idXR0b25zKSByZXR1cm4gZmFsc2U7XHJcbiAgICBjb25zdCBjcmVhdGVCdXR0b24gPSB0aGlzLmRldGFpbHNDb25maWcuYnV0dG9ucy5maW5kKGIgPT4gYi5uYW1lID09PSAnY3JlYXRlJyk7XHJcbiAgICByZXR1cm4gY3JlYXRlQnV0dG9uICYmICghY3JlYXRlQnV0dG9uLmRpc2FibGVkIHx8ICFjcmVhdGVCdXR0b24uZGlzYWJsZWQodGhpcy52YWx1ZSkpO1xyXG4gIH1cclxuXHJcbiAgb25QZWVrQ2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQsIG1vZGU6ICdjcmVhdGUnIHwgJ3ZpZXcnKTogdm9pZCB7XHJcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuXHJcbiAgICBpZiAodGhpcy5kZXRhaWxzQ29uZmlnKSB7XHJcbiAgICAgIGNvbnN0IGR5bmFtaWNEYXRhID0gbW9kZSA9PT0gJ2NyZWF0ZScgPyB7fSA6IHsgW3RoaXMuZGV0YWlsc0NvbmZpZy5oZXJvRmllbGRdOiB0aGlzLnZhbHVlIH07XHJcblxyXG5cclxuICAgICAgaWYgKG1vZGUgPT09ICd2aWV3JyAmJiAhdGhpcy5kZXRhaWxzQ29uZmlnLmJ1dHRvbnMuc29tZShiID0+IGIubmFtZSA9PT0gJ3ZpZXcnKSkge1xyXG4gICAgICAgIHRoaXMuZGV0YWlsc0NvbmZpZy5idXR0b25zLnB1c2goeyBuYW1lOiAndmlldycsIGRpYWxvZzogdHJ1ZSB9KTtcclxuICAgICAgfVxyXG5cclxuICAgICAgdGhpcy5kaWFsb2dTZXJ2aWNlLm9wZW5Db25maWd1cmVkRGV0YWlsc0RpYWxvZyhcclxuICAgICAgICBtb2RlLFxyXG4gICAgICAgIGR5bmFtaWNEYXRhLFxyXG4gICAgICAgIHRoaXMuZGV0YWlsc0NvbmZpZyxcclxuICAgICAgICBEZXRhaWxzRGlhbG9nTGl0ZVxyXG4gICAgICApLnN1YnNjcmliZShyZXN1bHQgPT4ge1xyXG4gICAgICAgIGNvbnNvbGUubG9nKHJlc3VsdCk7XHJcblxyXG4gICAgICAgIGlmIChyZXN1bHQubWVzc2FnZSA9PT0gJ3N1Y2Nlc3MnKSB7XHJcbiAgICAgICAgICB0aGlzLnJlZnJlc2goZXZlbnQpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgIH0pO1xyXG5cclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMubWVzc2FnZVNlcnZpY2UudG9hc3QoXCJQZWVrIGNvbmZpZ3VyYXRpb24gZXJyb3JcIik7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxzcGEtc2VsZWN0LWNvbW1vbiBbd2lkdGhdPVwid2lkdGhcIiBbcmVhZG9ubHldPVwicmVhZG9ubHlcIiBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIiBbZGVmYXVsdEZpcnN0VmFsdWVdPVwiZGVmYXVsdEZpcnN0VmFsdWVcIlxyXG4gICAgICAgICAgICAgICAgICAgW3JlYWRvbmx5TW9kZV09XCJyZWFkb25seU1vZGVcIiBbaGludF09XCJoaW50XCIgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCIgW211bHRpcGxlXT1cIm11bHRpcGxlXCJcclxuICAgICAgICAgICAgICAgICAgIFtkaXNwbGF5XT1cImRpc3BsYXlcIiBbKHZhbHVlKV09XCJ2YWx1ZVwiIFtvcHRpb25zXT1cIm9wdGlvbnNcIiBbbWFzdGVyT3B0aW9uc109XCJtYXN0ZXJPcHRpb25zXCIgW21hc3RlckZpZWxkXT1cIm1hc3RlckZpZWxkXCJcclxuICAgICAgICAgICAgICAgICAgIFtvcHRpb25WYWx1ZV09XCJvcHRpb25WYWx1ZVwiIFtvcHRpb25EaXNwbGF5XT1cIm9wdGlvbkRpc3BsYXlcIiBbb3B0aW9uRGlzcGxheUV4dHJhXT1cIm9wdGlvbkRpc3BsYXlFeHRyYVwiXHJcbiAgICAgICAgICAgICAgICAgICBbbnVsbGFibGVdPVwibnVsbGFibGVcIiBbaW5mb01lc3NhZ2VdPVwiaW5mb01lc3NhZ2VcIiBbY29weUNvbnRlbnRdPVwiY29weUNvbnRlbnRcIiBbbG9hZEFjdGlvbl09XCJsb2FkQWN0aW9uXCIgW2ZpZWxkXT1cImZpZWxkXCJcclxuICAgICAgICAgICAgICAgICAgICh2YWx1ZUNoYW5nZSk9XCJ2YWx1ZUNoYW5nZS5lbWl0KCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgICAgKGhvdmVyQ2hhbmdlKT1cIm9uSG92ZXJDaGFuZ2UoJGV2ZW50KVwiPlxyXG4gIDxuZy1jb250YWluZXIgYWRkaXRpb25hbEJ1dHRvbnM+XHJcbiAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAqbmdJZj1cImRldGFpbHNDb25maWcgJiYgY2FuQ3JlYXRlKCkgJiYgaXNIb3ZlcmVkXCIgKGNsaWNrKT1cIm9uUGVla0NsaWNrKCRldmVudCwgJ2NyZWF0ZScpXCIgbWF0VG9vbHRpcD1cIkFkZFwiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImFib3ZlXCI+XHJcbiAgICAgIDxtYXQtaWNvbiBzdHlsZT1cImNvbG9yOiBncmVlbjtcIj5hZGQ8L21hdC1pY29uPlxyXG4gICAgPC9idXR0b24+XHJcbiAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAqbmdJZj1cImRldGFpbHNDb25maWcgJiYgaXNIb3ZlcmVkICYmIHZhbHVlXCIgKGNsaWNrKT1cIm9uUGVla0NsaWNrKCRldmVudCwgJ3ZpZXcnKVwiIG1hdFRvb2x0aXA9XCJWaWV3XCIgbWF0VG9vbHRpcFBvc2l0aW9uPVwiYWJvdmVcIj5cclxuICAgICAgPG1hdC1pY29uIGNvbG9yPVwicHJpbWFyeVwiPmxhdW5jaDwvbWF0LWljb24+XHJcbiAgICA8L2J1dHRvbj5cclxuXHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvc3BhLXNlbGVjdC1jb21tb24+XHJcbiJdfQ==
|