tin-spa 2.6.5 → 2.6.6
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/select/select.component.mjs +16 -7
- package/esm2020/lib/components/select-internal/select-internal.component.mjs +16 -7
- 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/pages/accounts/accountDialog.component.mjs +1 -1
- package/esm2020/lib/pages/create-account/create-account.component.mjs +1 -1
- package/esm2020/lib/pages/profile/profile.component.mjs +1 -1
- package/esm2020/lib/pages/tenant-settings/tenant-settings.component.mjs +1 -1
- package/esm2020/lib/pages/transactions/transactDialog.component.mjs +1 -1
- package/fesm2015/tin-spa.mjs +39 -21
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +39 -21
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +1 -6
- package/lib/components/select/select.component.d.ts +4 -3
- package/lib/components/select-internal/select-internal.component.d.ts +4 -3
- 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;AA4DD,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  peekConfig ?: PeekDialogConfig;\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\nexport interface PeekDialogConfig{\r\n  detailsConfig: DetailsDialogConfig\r\n  create? : boolean\r\n  view? : boolean\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":"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"]}
|
|
@@ -20,11 +20,20 @@ export class SelectComponent extends SelectCommonComponent {
|
|
|
20
20
|
onHoverChange(isHovered) {
|
|
21
21
|
this.isHovered = isHovered;
|
|
22
22
|
}
|
|
23
|
+
canCreate() {
|
|
24
|
+
if (!this.detailsConfig.buttons)
|
|
25
|
+
return false;
|
|
26
|
+
const createButton = this.detailsConfig.buttons.find(b => b.name === 'create');
|
|
27
|
+
return createButton && (!createButton.disabled || !createButton.disabled(this.value));
|
|
28
|
+
}
|
|
23
29
|
onPeekClick(event, mode) {
|
|
24
30
|
event.stopPropagation();
|
|
25
|
-
if (this.
|
|
26
|
-
const dynamicData = mode === 'create' ? {} : { [this.
|
|
27
|
-
|
|
31
|
+
if (this.detailsConfig) {
|
|
32
|
+
const dynamicData = mode === 'create' ? {} : { [this.detailsConfig.heroField]: this.value };
|
|
33
|
+
if (mode === 'view' && !this.detailsConfig.buttons.some(b => b.name === 'view')) {
|
|
34
|
+
this.detailsConfig.buttons.push({ name: 'view', dialog: true });
|
|
35
|
+
}
|
|
36
|
+
this.dialogService.openConfiguredDetailsDialog(mode, dynamicData, this.detailsConfig, DetailsDialogInternal).subscribe(result => {
|
|
28
37
|
console.log(result);
|
|
29
38
|
if (result.message === 'success') {
|
|
30
39
|
this.refresh(event);
|
|
@@ -37,11 +46,11 @@ export class SelectComponent extends SelectCommonComponent {
|
|
|
37
46
|
}
|
|
38
47
|
}
|
|
39
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 });
|
|
40
|
-
SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectComponent, selector: "spa-select", inputs: {
|
|
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 && value\" (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"], outputs: ["valueChange", "hoverChange"] }] });
|
|
41
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectComponent, decorators: [{
|
|
42
51
|
type: Component,
|
|
43
|
-
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=\"
|
|
44
|
-
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }]; }, propDecorators: {
|
|
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 && value\" (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
|
+
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }]; }, propDecorators: { detailsConfig: [{
|
|
45
54
|
type: Input
|
|
46
55
|
}] } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0L3NlbGVjdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixLQUFLLEVBQWtCLE1BQU0sZUFBZSxDQUFDO0FBSS9FLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDOzs7Ozs7Ozs7O0FBUTNGLE1BQU0sT0FBTyxlQUFnQixTQUFRLHFCQUFxQjtJQUV4RCxZQUNxQixjQUE4QixFQUFxQixXQUEyQixFQUN6RixhQUE0QjtRQUdwQyxLQUFLLENBQUMsY0FBYyxFQUFDLFdBQVcsQ0FBQyxDQUFDO1FBSmYsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQXFCLGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtRQUN6RixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtJQUl0QyxDQUFDO0lBTUQsYUFBYSxDQUFDLFNBQWtCO1FBQzlCLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQzdCLENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTztZQUFFLE9BQU8sS0FBSyxDQUFDO1FBQzlDLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssUUFBUSxDQUFDLENBQUM7UUFDL0UsT0FBTyxZQUFZLElBQUksQ0FBQyxDQUFDLFlBQVksQ0FBQyxRQUFRLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBaUIsRUFBRSxJQUF1QjtRQUNwRCxLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RCLE1BQU0sV0FBVyxHQUFHLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBRzVGLElBQUksSUFBSSxLQUFLLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssTUFBTSxDQUFDLEVBQUU7Z0JBQy9FLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7YUFDakU7WUFFRCxJQUFJLENBQUMsYUFBYSxDQUFDLDJCQUEyQixDQUM1QyxJQUFJLEVBQ0osV0FBVyxFQUNYLElBQUksQ0FBQyxhQUFhLEVBQ2xCLHFCQUFxQixDQUN0QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFFcEIsSUFBSSxNQUFNLENBQUMsT0FBTyxLQUFLLFNBQVMsRUFBQztvQkFDL0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztpQkFDckI7WUFFSCxDQUFDLENBQUMsQ0FBQztTQUVKO2FBQU07WUFDTCxJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1NBQ3ZEO0lBQ0gsQ0FBQzs7NEdBcERVLGVBQWU7Z0dBQWYsZUFBZSxxSENiNUIsczJDQWlCQTsyRkRKYSxlQUFlO2tCQUwzQixTQUFTOytCQUNFLFlBQVk7OEpBY2IsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgIEFjdGlvbiwgQXBpUmVzcG9uc2UsIEJ1dHRvbiwgRGV0YWlsc0RpYWxvZ0NvbmZpZyB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XHJcbmltcG9ydCB7IE1lc3NhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbWVzc2FnZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGlhbG9nU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2RpYWxvZy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU2VsZWN0Q29tbW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vc2VsZWN0LWNvbW1vbi9zZWxlY3QtY29tbW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERldGFpbHNEaWFsb2dJbnRlcm5hbCB9IGZyb20gJy4uL3RhYmxlLWludGVybmFsL2RldGFpbHNEaWFsb2ctaW50ZXJuYWwuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRGF0YVNlcnZpY2VMaWIgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9kYXRhbGliLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtc2VsZWN0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zZWxlY3QuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RDb21wb25lbnQgZXh0ZW5kcyBTZWxlY3RDb21tb25Db21wb25lbnQge1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBtZXNzYWdlU2VydmljZTogTWVzc2FnZVNlcnZpY2UsIHByb3RlY3RlZCBvdmVycmlkZSBkYXRhU2VydmljZTogRGF0YVNlcnZpY2VMaWIsXHJcbiAgICBwcml2YXRlIGRpYWxvZ1NlcnZpY2U6IERpYWxvZ1NlcnZpY2UsXHJcblxyXG4gICkge1xyXG4gICAgc3VwZXIobWVzc2FnZVNlcnZpY2UsZGF0YVNlcnZpY2UpO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KCkgZGV0YWlsc0NvbmZpZzogRGV0YWlsc0RpYWxvZ0NvbmZpZztcclxuXHJcblxyXG5cclxuICBvbkhvdmVyQ2hhbmdlKGlzSG92ZXJlZDogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgdGhpcy5pc0hvdmVyZWQgPSBpc0hvdmVyZWQ7XHJcbiAgfVxyXG5cclxuICBjYW5DcmVhdGUoKTogYm9vbGVhbiB7XHJcbiAgICBpZiAoIXRoaXMuZGV0YWlsc0NvbmZpZy5idXR0b25zKSByZXR1cm4gZmFsc2U7XHJcbiAgICBjb25zdCBjcmVhdGVCdXR0b24gPSB0aGlzLmRldGFpbHNDb25maWcuYnV0dG9ucy5maW5kKGIgPT4gYi5uYW1lID09PSAnY3JlYXRlJyk7XHJcbiAgICByZXR1cm4gY3JlYXRlQnV0dG9uICYmICghY3JlYXRlQnV0dG9uLmRpc2FibGVkIHx8ICFjcmVhdGVCdXR0b24uZGlzYWJsZWQodGhpcy52YWx1ZSkpO1xyXG4gIH1cclxuXHJcbiAgb25QZWVrQ2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQsIG1vZGU6ICdjcmVhdGUnIHwgJ3ZpZXcnKTogdm9pZCB7XHJcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuXHJcbiAgICBpZiAodGhpcy5kZXRhaWxzQ29uZmlnKSB7XHJcbiAgICAgIGNvbnN0IGR5bmFtaWNEYXRhID0gbW9kZSA9PT0gJ2NyZWF0ZScgPyB7fSA6IHsgW3RoaXMuZGV0YWlsc0NvbmZpZy5oZXJvRmllbGRdOiB0aGlzLnZhbHVlIH07XHJcblxyXG5cclxuICAgICAgaWYgKG1vZGUgPT09ICd2aWV3JyAmJiAhdGhpcy5kZXRhaWxzQ29uZmlnLmJ1dHRvbnMuc29tZShiID0+IGIubmFtZSA9PT0gJ3ZpZXcnKSkge1xyXG4gICAgICAgIHRoaXMuZGV0YWlsc0NvbmZpZy5idXR0b25zLnB1c2goeyBuYW1lOiAndmlldycsIGRpYWxvZzogdHJ1ZSB9KTtcclxuICAgICAgfVxyXG5cclxuICAgICAgdGhpcy5kaWFsb2dTZXJ2aWNlLm9wZW5Db25maWd1cmVkRGV0YWlsc0RpYWxvZyhcclxuICAgICAgICBtb2RlLFxyXG4gICAgICAgIGR5bmFtaWNEYXRhLFxyXG4gICAgICAgIHRoaXMuZGV0YWlsc0NvbmZpZyxcclxuICAgICAgICBEZXRhaWxzRGlhbG9nSW50ZXJuYWxcclxuICAgICAgKS5zdWJzY3JpYmUocmVzdWx0ID0+IHtcclxuICAgICAgICBjb25zb2xlLmxvZyhyZXN1bHQpO1xyXG5cclxuICAgICAgICBpZiAocmVzdWx0Lm1lc3NhZ2UgPT09ICdzdWNjZXNzJyl7XHJcbiAgICAgICAgICB0aGlzLnJlZnJlc2goZXZlbnQpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgIH0pO1xyXG5cclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMubWVzc2FnZVNlcnZpY2UudG9hc3QoXCJQZWVrIGNvbmZpZ3VyYXRpb24gZXJyb3JcIik7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuXHJcblxyXG59XHJcblxyXG4iLCI8c3BhLXNlbGVjdC1jb21tb24gW3dpZHRoXT1cIndpZHRoXCIgW3JlYWRvbmx5XT1cInJlYWRvbmx5XCIgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCIgW2RlZmF1bHRGaXJzdFZhbHVlXT1cImRlZmF1bHRGaXJzdFZhbHVlXCJcclxuICAgICAgICAgICAgICAgICAgIFtyZWFkb25seU1vZGVdPVwicmVhZG9ubHlNb2RlXCIgW2hpbnRdPVwiaGludFwiIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiIFttdWx0aXBsZV09XCJtdWx0aXBsZVwiXHJcbiAgICAgICAgICAgICAgICAgICBbZGlzcGxheV09XCJkaXNwbGF5XCIgWyh2YWx1ZSldPVwidmFsdWVcIiBbb3B0aW9uc109XCJvcHRpb25zXCIgW21hc3Rlck9wdGlvbnNdPVwibWFzdGVyT3B0aW9uc1wiIFttYXN0ZXJGaWVsZF09XCJtYXN0ZXJGaWVsZFwiXHJcbiAgICAgICAgICAgICAgICAgICBbb3B0aW9uVmFsdWVdPVwib3B0aW9uVmFsdWVcIiBbb3B0aW9uRGlzcGxheV09XCJvcHRpb25EaXNwbGF5XCIgW29wdGlvbkRpc3BsYXlFeHRyYV09XCJvcHRpb25EaXNwbGF5RXh0cmFcIlxyXG4gICAgICAgICAgICAgICAgICAgW251bGxhYmxlXT1cIm51bGxhYmxlXCIgW2luZm9NZXNzYWdlXT1cImluZm9NZXNzYWdlXCIgW2NvcHlDb250ZW50XT1cImNvcHlDb250ZW50XCIgW2xvYWRBY3Rpb25dPVwibG9hZEFjdGlvblwiXHJcbiAgICAgICAgICAgICAgICAgICAodmFsdWVDaGFuZ2UpPVwidmFsdWVDaGFuZ2UuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgICAgIChob3ZlckNoYW5nZSk9XCJvbkhvdmVyQ2hhbmdlKCRldmVudClcIj5cclxuICA8bmctY29udGFpbmVyIGFkZGl0aW9uYWxCdXR0b25zPlxyXG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gKm5nSWY9XCJkZXRhaWxzQ29uZmlnICYmIGNhbkNyZWF0ZSgpICYmIGlzSG92ZXJlZCAmJiB2YWx1ZVwiIChjbGljayk9XCJvblBlZWtDbGljaygkZXZlbnQsICdjcmVhdGUnKVwiIG1hdFRvb2x0aXA9XCJBZGRcIiBtYXRUb29sdGlwUG9zaXRpb249XCJhYm92ZVwiPlxyXG4gICAgICA8bWF0LWljb24gc3R5bGU9XCJjb2xvcjogZ3JlZW47XCI+YWRkPC9tYXQtaWNvbj5cclxuICAgIDwvYnV0dG9uPlxyXG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gKm5nSWY9XCJkZXRhaWxzQ29uZmlnICYmIGlzSG92ZXJlZCAmJiB2YWx1ZVwiIChjbGljayk9XCJvblBlZWtDbGljaygkZXZlbnQsICd2aWV3JylcIiBtYXRUb29sdGlwPVwiVmlld1wiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImFib3ZlXCI+XHJcbiAgICAgIDxtYXQtaWNvbiBjb2xvcj1cInByaW1hcnlcIj5sYXVuY2g8L21hdC1pY29uPlxyXG4gICAgPC9idXR0b24+XHJcblxyXG4gIDwvbmctY29udGFpbmVyPlxyXG48L3NwYS1zZWxlY3QtY29tbW9uPlxyXG4iXX0=
|
|
@@ -20,11 +20,20 @@ export class SelectInternalComponent extends SelectCommonComponent {
|
|
|
20
20
|
onHoverChange(isHovered) {
|
|
21
21
|
this.isHovered = isHovered;
|
|
22
22
|
}
|
|
23
|
+
canCreate() {
|
|
24
|
+
if (!this.detailsConfig.buttons)
|
|
25
|
+
return false;
|
|
26
|
+
const createButton = this.detailsConfig.buttons.find(b => b.name === 'create');
|
|
27
|
+
return createButton && (!createButton.disabled || !createButton.disabled(this.value));
|
|
28
|
+
}
|
|
23
29
|
onPeekClick(event, mode) {
|
|
24
30
|
event.stopPropagation();
|
|
25
|
-
if (this.
|
|
26
|
-
const dynamicData = mode === 'create' ? {} : { [this.
|
|
27
|
-
|
|
31
|
+
if (this.detailsConfig) {
|
|
32
|
+
const dynamicData = mode === 'create' ? {} : { [this.detailsConfig.heroField]: this.value };
|
|
33
|
+
if (mode === 'view' && !this.detailsConfig.buttons.some(b => b.name === 'view')) {
|
|
34
|
+
this.detailsConfig.buttons.push({ name: 'view', dialog: true });
|
|
35
|
+
}
|
|
36
|
+
this.dialogService.openConfiguredDetailsDialog(mode, dynamicData, this.detailsConfig, DetailsDialogLite).subscribe(result => {
|
|
28
37
|
console.log(result);
|
|
29
38
|
if (result.message === 'success') {
|
|
30
39
|
this.refresh(event);
|
|
@@ -37,11 +46,11 @@ export class SelectInternalComponent extends SelectCommonComponent {
|
|
|
37
46
|
}
|
|
38
47
|
}
|
|
39
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 });
|
|
40
|
-
SelectInternalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectInternalComponent, selector: "spa-select-internal", inputs: {
|
|
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 && value\" (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"], outputs: ["valueChange", "hoverChange"] }] });
|
|
41
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectInternalComponent, decorators: [{
|
|
42
51
|
type: Component,
|
|
43
|
-
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=\"
|
|
44
|
-
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }]; }, propDecorators: {
|
|
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 && value\" (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
|
+
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }]; }, propDecorators: { detailsConfig: [{
|
|
45
54
|
type: Input
|
|
46
55
|
}] } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWludGVybmFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3NlbGVjdC1pbnRlcm5hbC9zZWxlY3QtaW50ZXJuYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0LWludGVybmFsL3NlbGVjdC1pbnRlcm5hbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixLQUFLLEVBQWtCLE1BQU0sZUFBZSxDQUFDO0FBSS9FLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRWpGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOzs7Ozs7Ozs7O0FBTy9FLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxxQkFBcUI7SUFDaEUsWUFDcUIsY0FBOEIsRUFBcUIsV0FBMkIsRUFDekYsYUFBNEI7UUFHcEMsS0FBSyxDQUFDLGNBQWMsRUFBRSxXQUFXLENBQUMsQ0FBQztRQUpoQixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFBcUIsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBQ3pGLGtCQUFhLEdBQWIsYUFBYSxDQUFlO0lBSXRDLENBQUM7SUFNRCxhQUFhLENBQUMsU0FBa0I7UUFDOUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDN0IsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDOUMsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQztRQUMvRSxPQUFPLFlBQVksSUFBSSxDQUFDLENBQUMsWUFBWSxDQUFDLFFBQVEsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDeEYsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFpQixFQUFFLElBQXVCO1FBQ3BELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUV4QixJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDdEIsTUFBTSxXQUFXLEdBQUcsSUFBSSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFHNUYsSUFBSSxJQUFJLEtBQUssTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxNQUFNLENBQUMsRUFBRTtnQkFDL0UsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQzthQUNqRTtZQUVELElBQUksQ0FBQyxhQUFhLENBQUMsMkJBQTJCLENBQzVDLElBQUksRUFDSixXQUFXLEVBQ1gsSUFBSSxDQUFDLGFBQWEsRUFDbEIsaUJBQWlCLENBQ2xCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFO2dCQUNuQixPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO2dCQUVwQixJQUFJLE1BQU0sQ0FBQyxPQUFPLEtBQUssU0FBUyxFQUFFO29CQUNoQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUNyQjtZQUVILENBQUMsQ0FBQyxDQUFDO1NBRUo7YUFBTTtZQUNMLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7U0FDdkQ7SUFDSCxDQUFDOztvSEFuRFUsdUJBQXVCO3dHQUF2Qix1QkFBdUIsOEhDYnBDLHMyQ0FpQkE7MkZESmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHFCQUFxQjs4SkFhdEIsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aW9uLCBBcGlSZXNwb25zZSwgRGV0YWlsc0RpYWxvZ0NvbmZpZyB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XHJcbmltcG9ydCB7IE1lc3NhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbWVzc2FnZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGlhbG9nU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2RpYWxvZy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU2VsZWN0Q29tbW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vc2VsZWN0LWNvbW1vbi9zZWxlY3QtY29tbW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGFTZXJ2aWNlTGliIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZGF0YWxpYi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGV0YWlsc0RpYWxvZ0xpdGUgfSBmcm9tICcuLi90YWJsZS1saXRlL2RldGFpbHNEaWFsb2ctbGl0ZS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtc2VsZWN0LWludGVybmFsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LWludGVybmFsLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zZWxlY3QtaW50ZXJuYWwuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RJbnRlcm5hbENvbXBvbmVudCBleHRlbmRzIFNlbGVjdENvbW1vbkNvbXBvbmVudCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgbWVzc2FnZVNlcnZpY2U6IE1lc3NhZ2VTZXJ2aWNlLCBwcm90ZWN0ZWQgb3ZlcnJpZGUgZGF0YVNlcnZpY2U6IERhdGFTZXJ2aWNlTGliLFxyXG4gICAgcHJpdmF0ZSBkaWFsb2dTZXJ2aWNlOiBEaWFsb2dTZXJ2aWNlLFxyXG5cclxuICApIHtcclxuICAgIHN1cGVyKG1lc3NhZ2VTZXJ2aWNlLCBkYXRhU2VydmljZSk7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKSBkZXRhaWxzQ29uZmlnOiBEZXRhaWxzRGlhbG9nQ29uZmlnO1xyXG5cclxuXHJcblxyXG4gIG9uSG92ZXJDaGFuZ2UoaXNIb3ZlcmVkOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICB0aGlzLmlzSG92ZXJlZCA9IGlzSG92ZXJlZDtcclxuICB9XHJcblxyXG4gIGNhbkNyZWF0ZSgpOiBib29sZWFuIHtcclxuICAgIGlmICghdGhpcy5kZXRhaWxzQ29uZmlnLmJ1dHRvbnMpIHJldHVybiBmYWxzZTtcclxuICAgIGNvbnN0IGNyZWF0ZUJ1dHRvbiA9IHRoaXMuZGV0YWlsc0NvbmZpZy5idXR0b25zLmZpbmQoYiA9PiBiLm5hbWUgPT09ICdjcmVhdGUnKTtcclxuICAgIHJldHVybiBjcmVhdGVCdXR0b24gJiYgKCFjcmVhdGVCdXR0b24uZGlzYWJsZWQgfHwgIWNyZWF0ZUJ1dHRvbi5kaXNhYmxlZCh0aGlzLnZhbHVlKSk7XHJcbiAgfVxyXG5cclxuICBvblBlZWtDbGljayhldmVudDogTW91c2VFdmVudCwgbW9kZTogJ2NyZWF0ZScgfCAndmlldycpOiB2b2lkIHtcclxuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG5cclxuICAgIGlmICh0aGlzLmRldGFpbHNDb25maWcpIHtcclxuICAgICAgY29uc3QgZHluYW1pY0RhdGEgPSBtb2RlID09PSAnY3JlYXRlJyA/IHt9IDogeyBbdGhpcy5kZXRhaWxzQ29uZmlnLmhlcm9GaWVsZF06IHRoaXMudmFsdWUgfTtcclxuXHJcblxyXG4gICAgICBpZiAobW9kZSA9PT0gJ3ZpZXcnICYmICF0aGlzLmRldGFpbHNDb25maWcuYnV0dG9ucy5zb21lKGIgPT4gYi5uYW1lID09PSAndmlldycpKSB7XHJcbiAgICAgICAgdGhpcy5kZXRhaWxzQ29uZmlnLmJ1dHRvbnMucHVzaCh7IG5hbWU6ICd2aWV3JywgZGlhbG9nOiB0cnVlIH0pO1xyXG4gICAgICB9XHJcblxyXG4gICAgICB0aGlzLmRpYWxvZ1NlcnZpY2Uub3BlbkNvbmZpZ3VyZWREZXRhaWxzRGlhbG9nKFxyXG4gICAgICAgIG1vZGUsXHJcbiAgICAgICAgZHluYW1pY0RhdGEsXHJcbiAgICAgICAgdGhpcy5kZXRhaWxzQ29uZmlnLFxyXG4gICAgICAgIERldGFpbHNEaWFsb2dMaXRlXHJcbiAgICAgICkuc3Vic2NyaWJlKHJlc3VsdCA9PiB7XHJcbiAgICAgICAgY29uc29sZS5sb2cocmVzdWx0KTtcclxuXHJcbiAgICAgICAgaWYgKHJlc3VsdC5tZXNzYWdlID09PSAnc3VjY2VzcycpIHtcclxuICAgICAgICAgIHRoaXMucmVmcmVzaChldmVudCk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgfSk7XHJcblxyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5tZXNzYWdlU2VydmljZS50b2FzdChcIlBlZWsgY29uZmlndXJhdGlvbiBlcnJvclwiKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPHNwYS1zZWxlY3QtY29tbW9uIFt3aWR0aF09XCJ3aWR0aFwiIFtyZWFkb25seV09XCJyZWFkb25seVwiIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiIFtkZWZhdWx0Rmlyc3RWYWx1ZV09XCJkZWZhdWx0Rmlyc3RWYWx1ZVwiXHJcbiAgICAgICAgICAgICAgICAgICBbcmVhZG9ubHlNb2RlXT1cInJlYWRvbmx5TW9kZVwiIFtoaW50XT1cImhpbnRcIiBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIiBbbXVsdGlwbGVdPVwibXVsdGlwbGVcIlxyXG4gICAgICAgICAgICAgICAgICAgW2Rpc3BsYXldPVwiZGlzcGxheVwiIFsodmFsdWUpXT1cInZhbHVlXCIgW29wdGlvbnNdPVwib3B0aW9uc1wiIFttYXN0ZXJPcHRpb25zXT1cIm1hc3Rlck9wdGlvbnNcIiBbbWFzdGVyRmllbGRdPVwibWFzdGVyRmllbGRcIlxyXG4gICAgICAgICAgICAgICAgICAgW29wdGlvblZhbHVlXT1cIm9wdGlvblZhbHVlXCIgW29wdGlvbkRpc3BsYXldPVwib3B0aW9uRGlzcGxheVwiIFtvcHRpb25EaXNwbGF5RXh0cmFdPVwib3B0aW9uRGlzcGxheUV4dHJhXCJcclxuICAgICAgICAgICAgICAgICAgIFtudWxsYWJsZV09XCJudWxsYWJsZVwiIFtpbmZvTWVzc2FnZV09XCJpbmZvTWVzc2FnZVwiIFtjb3B5Q29udGVudF09XCJjb3B5Q29udGVudFwiIFtsb2FkQWN0aW9uXT1cImxvYWRBY3Rpb25cIlxyXG4gICAgICAgICAgICAgICAgICAgKHZhbHVlQ2hhbmdlKT1cInZhbHVlQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAgICAoaG92ZXJDaGFuZ2UpPVwib25Ib3ZlckNoYW5nZSgkZXZlbnQpXCI+XHJcbiAgPG5nLWNvbnRhaW5lciBhZGRpdGlvbmFsQnV0dG9ucz5cclxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uICpuZ0lmPVwiZGV0YWlsc0NvbmZpZyAmJiBjYW5DcmVhdGUoKSAmJiBpc0hvdmVyZWQgJiYgdmFsdWVcIiAoY2xpY2spPVwib25QZWVrQ2xpY2soJGV2ZW50LCAnY3JlYXRlJylcIiBtYXRUb29sdGlwPVwiQWRkXCIgbWF0VG9vbHRpcFBvc2l0aW9uPVwiYWJvdmVcIj5cclxuICAgICAgPG1hdC1pY29uIHN0eWxlPVwiY29sb3I6IGdyZWVuO1wiPmFkZDwvbWF0LWljb24+XHJcbiAgICA8L2J1dHRvbj5cclxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uICpuZ0lmPVwiZGV0YWlsc0NvbmZpZyAmJiBpc0hvdmVyZWQgJiYgdmFsdWVcIiAoY2xpY2spPVwib25QZWVrQ2xpY2soJGV2ZW50LCAndmlldycpXCIgbWF0VG9vbHRpcD1cIlZpZXdcIiBtYXRUb29sdGlwUG9zaXRpb249XCJhYm92ZVwiPlxyXG4gICAgICA8bWF0LWljb24gY29sb3I9XCJwcmltYXJ5XCI+bGF1bmNoPC9tYXQtaWNvbj5cclxuICAgIDwvYnV0dG9uPlxyXG5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9zcGEtc2VsZWN0LWNvbW1vbj5cclxuIl19
|
|
@@ -240,10 +240,10 @@ export class DetailsDialog {
|
|
|
240
240
|
}
|
|
241
241
|
}
|
|
242
242
|
DetailsDialog.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DetailsDialog, deps: [{ token: i1.BreakpointObserver }, { token: i2.LoaderService }, { token: i3.DataServiceLib }, { token: i4.MessageService }, { token: i5.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i6.ButtonService }, { token: i7.DialogService }], target: i0.ɵɵFactoryTarget.Component });
|
|
243
|
-
DetailsDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DetailsDialog, selector: "spa-detailsDialog", outputs: { inputChange: "inputChange" }, ngImport: i0, template: "<div class=\"dialog-container\">\r\n\r\n <div class=\"dialog-content\">\r\n\r\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n <div class=\"row d-flex align-items-center mt-0\">\r\n\r\n <div class=\"col\">\r\n <h2 mat-dialog-title>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\">\r\n\r\n <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n </div>\r\n\r\n <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n </div>\r\n\r\n </div>\r\n\r\n <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\r\n\r\n <div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n <p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n <spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\">\r\n <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n <spa-select\r\n [display]=\"field.alias ?? field.name | camelToWords\"\r\n [width]=\"field.width\"\r\n [nullable]=\"field.nullable\"\r\n [options]=\"field.options\"\r\n [masterOptions]=\"field.masterOptions\"\r\n [masterField]=\"field.masterField\"\r\n [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n [optionValue]=\"field.optionValue ?? 'value'\"\r\n [(value)]=\"data[field.name]\"\r\n [defaultFirstValue]=\"field.defaultFirstValue\"\r\n [readonly]=\"testReadOnly(field)\"\r\n [hint]=\"field.hint\"\r\n [
|
|
243
|
+
DetailsDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DetailsDialog, selector: "spa-detailsDialog", outputs: { inputChange: "inputChange" }, ngImport: i0, template: "<div class=\"dialog-container\">\r\n\r\n <div class=\"dialog-content\">\r\n\r\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n <div class=\"row d-flex align-items-center mt-0\">\r\n\r\n <div class=\"col\">\r\n <h2 mat-dialog-title>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\">\r\n\r\n <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n </div>\r\n\r\n <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n </div>\r\n\r\n </div>\r\n\r\n <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\r\n\r\n <div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n <p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n <spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\">\r\n <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n <spa-select\r\n [display]=\"field.alias ?? field.name | camelToWords\"\r\n [width]=\"field.width\"\r\n [nullable]=\"field.nullable\"\r\n [options]=\"field.options\"\r\n [masterOptions]=\"field.masterOptions\"\r\n [masterField]=\"field.masterField\"\r\n [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n [optionValue]=\"field.optionValue ?? 'value'\"\r\n [(value)]=\"data[field.name]\"\r\n [defaultFirstValue]=\"field.defaultFirstValue\"\r\n [readonly]=\"testReadOnly(field)\"\r\n [hint]=\"field.hint\"\r\n [detailsConfig]=\"field.detailsConfig\"\r\n [loadAction]=\"field.loadAction\"\r\n [infoMessage]=\"field.infoMessage\"\r\n [copyContent]=\"field.copyContent\"\r\n (valueChange)=\"selectChanged(field)\"\r\n ></spa-select>\r\n </ng-template>\r\n </spa-form>\r\n\r\n\r\n <mat-tab-group *ngIf=\"tableConfigs\">\r\n\r\n <ng-container *ngFor=\"let tbl of tableConfigs\">\r\n\r\n <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n <ng-template matTabLabel>\r\n <span>{{tbl.title ?? 'Untitled'}}</span>\r\n </ng-template>\r\n\r\n <spa-table-internal [config]=\"tbl\" [hideTitle]=\"true\" [reload]=\"tableReload\" (dataLoad)=\"loadData(formConfig.loadAction, false)\"></spa-table-internal>\r\n\r\n </mat-tab>\r\n </ng-container>\r\n\r\n\r\n </mat-tab-group>\r\n\r\n\r\n\r\n </div>\r\n\r\n </mat-dialog-content>\r\n\r\n\r\n </div>\r\n\r\n <mat-dialog-actions >\r\n\r\n <div>\r\n\r\n <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n </button>\r\n\r\n <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n </button>\r\n\r\n <ng-container *ngFor=\"let btn of extraButtons\">\r\n <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name | titlecase}}\r\n </button>\r\n </ng-container>\r\n\r\n <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n <ng-container *ngFor=\"let btn of extraButtons\">\r\n <button *ngIf=\"testVisible(details,btn.name)\" mat-icon-button matTooltipPosition=\"above\" [matTooltip]=\"btn.tip ?? btn.name | titlecase\" [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n </button>\r\n </ng-container>\r\n\r\n <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [disabled]=\"isProcessing\" style=\"color: red;\" (click)=\"delete()\" *ngIf=\"formConfig.mode!='create' && deleteButton\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n\r\n\r\n </mat-dialog-actions>\r\n\r\n\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.dialog-container{display:flex;flex-direction:column;height:100%}.dialog-content{flex:1;display:flex;flex-direction:column}.dialog-scroll-content{flex:1;overflow-y:auto}mat-dialog-actions{flex-shrink:0}\n"], dependencies: [{ kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i9.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: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i5.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i5.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i5.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i11.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple"], exportAs: ["matTabGroup"] }, { kind: "directive", type: i11.MatTabLabel, selector: "[mat-tab-label], [matTabLabel]" }, { kind: "component", type: i11.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "directive", type: i12.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i13.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i14.SelectComponent, selector: "spa-select", inputs: ["detailsConfig"] }, { kind: "component", type: i15.StepsComponent, selector: "spa-steps", inputs: ["value", "config", "data"] }, { kind: "component", type: i16.TableInternalComponent, selector: "spa-table-internal", inputs: ["hideTitle", "data", "tileData", "config", "reload"], outputs: ["dataLoad", "refreshClick", "searchClick", "createClick", "actionClick", "inputChange", "actionResponse"] }, { kind: "component", type: i17.FormComponent, selector: "spa-form", inputs: ["files", "data", "config"], outputs: ["buttonClick", "inputChange"] }, { kind: "component", type: i18.AlertComponent, selector: "spa-alert", inputs: ["alertMessages", "data"] }, { kind: "pipe", type: i8.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: i19.CamelToWordsPipe, name: "camelToWords" }] });
|
|
244
244
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DetailsDialog, decorators: [{
|
|
245
245
|
type: Component,
|
|
246
|
-
args: [{ selector: 'spa-detailsDialog', template: "<div class=\"dialog-container\">\r\n\r\n <div class=\"dialog-content\">\r\n\r\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n <div class=\"row d-flex align-items-center mt-0\">\r\n\r\n <div class=\"col\">\r\n <h2 mat-dialog-title>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\">\r\n\r\n <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n </div>\r\n\r\n <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n </div>\r\n\r\n </div>\r\n\r\n <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\r\n\r\n <div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n <p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n <spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\">\r\n <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n <spa-select\r\n [display]=\"field.alias ?? field.name | camelToWords\"\r\n [width]=\"field.width\"\r\n [nullable]=\"field.nullable\"\r\n [options]=\"field.options\"\r\n [masterOptions]=\"field.masterOptions\"\r\n [masterField]=\"field.masterField\"\r\n [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n [optionValue]=\"field.optionValue ?? 'value'\"\r\n [(value)]=\"data[field.name]\"\r\n [defaultFirstValue]=\"field.defaultFirstValue\"\r\n [readonly]=\"testReadOnly(field)\"\r\n [hint]=\"field.hint\"\r\n [
|
|
246
|
+
args: [{ selector: 'spa-detailsDialog', template: "<div class=\"dialog-container\">\r\n\r\n <div class=\"dialog-content\">\r\n\r\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n <div class=\"row d-flex align-items-center mt-0\">\r\n\r\n <div class=\"col\">\r\n <h2 mat-dialog-title>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\">\r\n\r\n <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n </div>\r\n\r\n <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n </div>\r\n\r\n </div>\r\n\r\n <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\r\n\r\n <div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n <p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n <spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\">\r\n <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n <spa-select\r\n [display]=\"field.alias ?? field.name | camelToWords\"\r\n [width]=\"field.width\"\r\n [nullable]=\"field.nullable\"\r\n [options]=\"field.options\"\r\n [masterOptions]=\"field.masterOptions\"\r\n [masterField]=\"field.masterField\"\r\n [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n [optionValue]=\"field.optionValue ?? 'value'\"\r\n [(value)]=\"data[field.name]\"\r\n [defaultFirstValue]=\"field.defaultFirstValue\"\r\n [readonly]=\"testReadOnly(field)\"\r\n [hint]=\"field.hint\"\r\n [detailsConfig]=\"field.detailsConfig\"\r\n [loadAction]=\"field.loadAction\"\r\n [infoMessage]=\"field.infoMessage\"\r\n [copyContent]=\"field.copyContent\"\r\n (valueChange)=\"selectChanged(field)\"\r\n ></spa-select>\r\n </ng-template>\r\n </spa-form>\r\n\r\n\r\n <mat-tab-group *ngIf=\"tableConfigs\">\r\n\r\n <ng-container *ngFor=\"let tbl of tableConfigs\">\r\n\r\n <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n <ng-template matTabLabel>\r\n <span>{{tbl.title ?? 'Untitled'}}</span>\r\n </ng-template>\r\n\r\n <spa-table-internal [config]=\"tbl\" [hideTitle]=\"true\" [reload]=\"tableReload\" (dataLoad)=\"loadData(formConfig.loadAction, false)\"></spa-table-internal>\r\n\r\n </mat-tab>\r\n </ng-container>\r\n\r\n\r\n </mat-tab-group>\r\n\r\n\r\n\r\n </div>\r\n\r\n </mat-dialog-content>\r\n\r\n\r\n </div>\r\n\r\n <mat-dialog-actions >\r\n\r\n <div>\r\n\r\n <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n </button>\r\n\r\n <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n </button>\r\n\r\n <ng-container *ngFor=\"let btn of extraButtons\">\r\n <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name | titlecase}}\r\n </button>\r\n </ng-container>\r\n\r\n <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n <ng-container *ngFor=\"let btn of extraButtons\">\r\n <button *ngIf=\"testVisible(details,btn.name)\" mat-icon-button matTooltipPosition=\"above\" [matTooltip]=\"btn.tip ?? btn.name | titlecase\" [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n </button>\r\n </ng-container>\r\n\r\n <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [disabled]=\"isProcessing\" style=\"color: red;\" (click)=\"delete()\" *ngIf=\"formConfig.mode!='create' && deleteButton\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n\r\n\r\n </mat-dialog-actions>\r\n\r\n\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.dialog-container{display:flex;flex-direction:column;height:100%}.dialog-content{flex:1;display:flex;flex-direction:column}.dialog-scroll-content{flex:1;overflow-y:auto}mat-dialog-actions{flex-shrink:0}\n"] }]
|
|
247
247
|
}], ctorParameters: function () { return [{ type: i1.BreakpointObserver }, { type: i2.LoaderService }, { type: i3.DataServiceLib }, { type: i4.MessageService }, { type: i5.MatDialogRef }, { type: i20.DetailsDialogConfig, decorators: [{
|
|
248
248
|
type: Inject,
|
|
249
249
|
args: [MAT_DIALOG_DATA]
|
|
@@ -251,4 +251,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
251
251
|
type: Output
|
|
252
252
|
}] } });
|
|
253
253
|
;
|
|
254
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detailsDialog.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.component.html"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, OnInit, Inject, Output, EventEmitter } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action, ApiResponse, StepConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Subject, config } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\n@Component({\r\n  selector: 'spa-detailsDialog',\r\n  templateUrl: './detailsDialog.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class DetailsDialog implements OnInit {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,public dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialog>, @Inject(MAT_DIALOG_DATA) public detailsConfig: DetailsDialogConfig, private buttonService: ButtonService,\r\n    private dialogService: DialogService)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n      }else {\r\n        this.smallScreen = false\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    const { tableConfig, tableConfigs, formConfig, stepConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.stepConfig = stepConfig;\r\n    this.buttons = buttons;\r\n\r\n    let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig,);\r\n\r\n    if (resp.loadByAction){\r\n      this.loadByAction = true;\r\n      formConfig.loadAction = resp.action;\r\n      this.loadData(resp.action, false);\r\n    }else{\r\n      this.details = resp.details;\r\n      DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n      this.loadByAction = false;\r\n      this.isLoadComplete = true;\r\n    }\r\n\r\n    this.fileField = DetailsDialogProcessor.setFileField(this.formConfig);\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    const { extraButtons, createButton, editButton, deleteButton } = DetailsDialogProcessor.setupButtons(this.formConfig, this.buttons);\r\n    this.extraButtons = extraButtons;\r\n    this.createButton = createButton;\r\n    this.editButton = editButton;\r\n    this.deleteButton = deleteButton;\r\n\r\n    this.setTitleAction();\r\n\r\n  }\r\n\r\n\r\n  titleAction = \"View\";\r\n  loadByAction = false;\r\n\r\n  extraButtons: Button[];\r\n  buttons: Button[];\r\n  createButton: Button;\r\n  editButton: Button;\r\n  deleteButton: Button;\r\n\r\n  // modeButton : Button\r\n  fileField: Field;\r\n  files: any[] = [];\r\n\r\n  tableReload: Subject<boolean> = new Subject();\r\n\r\n  tableConfig: TableConfig\r\n  tableConfigs\r\n  details: any\r\n  formConfig: FormConfig;\r\n  stepConfig : StepConfig;\r\n  smallScreen = false;\r\n\r\n  isLoadComplete: boolean = false;\r\n  isProcessing: boolean = false;\r\n\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n\r\n  loadData(action: Action, reload) {\r\n\r\n    if (action && this.loadByAction) {\r\n\r\n      this.dataService.CallApi(action).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (apiResponse.success) {\r\n          this.details = apiResponse.data\r\n          this.isLoadComplete = true;\r\n          // DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n          if(reload) this.tableReload.next(true);\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n\r\n  setMode(newMode){\r\n    this.formConfig.mode = newMode\r\n    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction(){\r\n    if (this.formConfig.fixedTitle) {\r\n      this.titleAction = \"\";\r\n      return;\r\n    }\r\n\r\n    this.titleAction = this.buttonService.getTitleAction(this.formConfig.mode, this.buttons);\r\n  }\r\n\r\n\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.buttons, name);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return button ? this.buttonService.testDisabled(button, row) : false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return button ? this.buttonService.isButtonVisible(button, row, this.isLoadComplete) : false;\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n    return this.buttonService.isTabVisible(tblConfig);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getVisibleFields() {\r\n    return this.formConfig.fields?.filter(x => Core.testVisible(this.formConfig, this.details, x))\r\n  }\r\n\r\n\r\n  create() {\r\n    this.handleButtonAction('create');\r\n  }\r\n\r\n  edit() {\r\n    this.handleButtonAction('edit');\r\n  }\r\n\r\n  delete() {\r\n    this.handleButtonAction('delete');\r\n  }\r\n\r\n\r\n  custom(button: Button ) {\r\n    if (button.dialog && button.detailsConfig) {\r\n      this.openNestedDetailsDialog(button);\r\n    } else {\r\n      this.handleButtonAction(button.name);\r\n    }\r\n  }\r\n\r\n  private openNestedDetailsDialog(button: Button): void {\r\n\r\n    this.dialogService.openConfiguredDetailsDialog( button.name, this.details, this.detailsConfig, DetailsDialog ).subscribe(result => {\r\n\r\n      if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result && result.message === 'success') {\r\n        this.refreshData();\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  private refreshData(): void {\r\n    if (this.formConfig.loadAction) {\r\n      this.loadData(this.formConfig.loadAction, true);\r\n    }\r\n  }\r\n\r\n  handleButtonAction(buttonName: string) {\r\n    const button = this.getButton(buttonName);\r\n    if (!button) return;\r\n\r\n    if (!button.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n    if (this.validateForm()) {\r\n      this.executeAction(button, this.details);\r\n    }\r\n  }\r\n\r\n  private validateForm(): boolean {\r\n    let validationResult = Core.validateObject(this.getVisibleFields(), this.details);\r\n    if (validationResult !== '') {\r\n      this.messageService.toast(validationResult);\r\n      return false;\r\n    }\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.formConfig.mode === 'create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return false;\r\n    }\r\n\r\n    // Validate composite fields\r\n    for (const field of this.getVisibleFields()) {\r\n      if (field.type === 'composite') {\r\n        validationResult = Core.validateObject(Core.getVisibleSubfields(this.formConfig,this.details, field), this.details);\r\n        if (validationResult !== '') {\r\n          this.messageService.toast(validationResult);\r\n          return false;\r\n        }\r\n      }\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private prepareActionData(button: Button, data: any): any {\r\n    if (button.action?.isFormData) {\r\n      const 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      formData.append(\"data\", JSON.stringify(data));\r\n      return formData;\r\n    }\r\n    return data;\r\n  }\r\n\r\n  private executeAction(button: Button, data: any) {\r\n    const actionData = this.prepareActionData(button, data);\r\n\r\n    if (button.confirm) {\r\n      this.messageService.confirm(button.confirm.message).subscribe((result) => {\r\n        if (result === \"yes\") {\r\n          this.performApiCall(button, actionData);\r\n        }\r\n      });\r\n    } else {\r\n      this.performApiCall(button, actionData);\r\n    }\r\n  }\r\n\r\n  private performApiCall(button: Button, data: any) {\r\n    this.dataService.CallApi(button.action, data).subscribe((apiResponse: ApiResponse) => {\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 if (apiResponse.message != \"success\" && apiResponse.message != \"\") {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: this.details } });\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n};\r\n\r\n\r\n\r\n","<div class=\"dialog-container\">\r\n\r\n  <div class=\"dialog-content\">\r\n\r\n    <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n    <div class=\"row d-flex align-items-center mt-0\">\r\n\r\n      <div class=\"col\">\r\n        <h2 mat-dialog-title>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n      </div>\r\n\r\n      <div class=\"col d-flex justify-content-end\">\r\n\r\n        <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n          <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n        </div>\r\n\r\n        <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n      </div>\r\n\r\n    </div>\r\n\r\n    <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n      <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\r\n\r\n      <div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n        <p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n        <spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\">\r\n          <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n            <spa-select\r\n              [display]=\"field.alias ?? field.name | camelToWords\"\r\n              [width]=\"field.width\"\r\n              [nullable]=\"field.nullable\"\r\n              [options]=\"field.options\"\r\n              [masterOptions]=\"field.masterOptions\"\r\n              [masterField]=\"field.masterField\"\r\n              [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n              [optionValue]=\"field.optionValue ?? 'value'\"\r\n              [(value)]=\"data[field.name]\"\r\n              [defaultFirstValue]=\"field.defaultFirstValue\"\r\n              [readonly]=\"testReadOnly(field)\"\r\n              [hint]=\"field.hint\"\r\n              [peekConfig]=\"field.peekConfig\"\r\n              [loadAction]=\"field.loadAction\"\r\n              [infoMessage]=\"field.infoMessage\"\r\n              [copyContent]=\"field.copyContent\"\r\n              (valueChange)=\"selectChanged(field)\"\r\n            ></spa-select>\r\n          </ng-template>\r\n        </spa-form>\r\n\r\n\r\n        <mat-tab-group *ngIf=\"tableConfigs\">\r\n\r\n          <ng-container *ngFor=\"let tbl of tableConfigs\">\r\n\r\n            <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n              <ng-template matTabLabel>\r\n                <span>{{tbl.title ?? 'Untitled'}}</span>\r\n              </ng-template>\r\n\r\n              <spa-table-internal [config]=\"tbl\" [hideTitle]=\"true\" [reload]=\"tableReload\" (dataLoad)=\"loadData(formConfig.loadAction, false)\"></spa-table-internal>\r\n\r\n            </mat-tab>\r\n          </ng-container>\r\n\r\n\r\n        </mat-tab-group>\r\n\r\n\r\n\r\n      </div>\r\n\r\n    </mat-dialog-content>\r\n\r\n\r\n  </div>\r\n\r\n  <mat-dialog-actions >\r\n\r\n    <div>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <ng-container *ngFor=\"let btn of extraButtons\">\r\n        <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n    </div>\r\n\r\n    <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n      <ng-container *ngFor=\"let btn of extraButtons\">\r\n        <button *ngIf=\"testVisible(details,btn.name)\" mat-icon-button matTooltipPosition=\"above\" [matTooltip]=\"btn.tip ?? btn.name | titlecase\" [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [disabled]=\"isProcessing\" style=\"color: red;\" (click)=\"delete()\" *ngIf=\"formConfig.mode!='create'  && deleteButton\"><mat-icon>delete</mat-icon></button>\r\n    </div>\r\n\r\n\r\n  </mat-dialog-actions>\r\n\r\n\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|
|
254
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detailsDialog.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.component.html"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, OnInit, Inject, Output, EventEmitter } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action, ApiResponse, StepConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Subject, config } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\n@Component({\r\n  selector: 'spa-detailsDialog',\r\n  templateUrl: './detailsDialog.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class DetailsDialog implements OnInit {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,public dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialog>, @Inject(MAT_DIALOG_DATA) public detailsConfig: DetailsDialogConfig, private buttonService: ButtonService,\r\n    private dialogService: DialogService)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n      }else {\r\n        this.smallScreen = false\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    const { tableConfig, tableConfigs, formConfig, stepConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.stepConfig = stepConfig;\r\n    this.buttons = buttons;\r\n\r\n    let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig,);\r\n\r\n    if (resp.loadByAction){\r\n      this.loadByAction = true;\r\n      formConfig.loadAction = resp.action;\r\n      this.loadData(resp.action, false);\r\n    }else{\r\n      this.details = resp.details;\r\n      DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n      this.loadByAction = false;\r\n      this.isLoadComplete = true;\r\n    }\r\n\r\n    this.fileField = DetailsDialogProcessor.setFileField(this.formConfig);\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    const { extraButtons, createButton, editButton, deleteButton } = DetailsDialogProcessor.setupButtons(this.formConfig, this.buttons);\r\n    this.extraButtons = extraButtons;\r\n    this.createButton = createButton;\r\n    this.editButton = editButton;\r\n    this.deleteButton = deleteButton;\r\n\r\n    this.setTitleAction();\r\n\r\n  }\r\n\r\n\r\n  titleAction = \"View\";\r\n  loadByAction = false;\r\n\r\n  extraButtons: Button[];\r\n  buttons: Button[];\r\n  createButton: Button;\r\n  editButton: Button;\r\n  deleteButton: Button;\r\n\r\n  // modeButton : Button\r\n  fileField: Field;\r\n  files: any[] = [];\r\n\r\n  tableReload: Subject<boolean> = new Subject();\r\n\r\n  tableConfig: TableConfig\r\n  tableConfigs\r\n  details: any\r\n  formConfig: FormConfig;\r\n  stepConfig : StepConfig;\r\n  smallScreen = false;\r\n\r\n  isLoadComplete: boolean = false;\r\n  isProcessing: boolean = false;\r\n\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n\r\n  loadData(action: Action, reload) {\r\n\r\n    if (action && this.loadByAction) {\r\n\r\n      this.dataService.CallApi(action).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (apiResponse.success) {\r\n          this.details = apiResponse.data\r\n          this.isLoadComplete = true;\r\n          // DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n          if(reload) this.tableReload.next(true);\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n\r\n  setMode(newMode){\r\n    this.formConfig.mode = newMode\r\n    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction(){\r\n    if (this.formConfig.fixedTitle) {\r\n      this.titleAction = \"\";\r\n      return;\r\n    }\r\n\r\n    this.titleAction = this.buttonService.getTitleAction(this.formConfig.mode, this.buttons);\r\n  }\r\n\r\n\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.buttons, name);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return button ? this.buttonService.testDisabled(button, row) : false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return button ? this.buttonService.isButtonVisible(button, row, this.isLoadComplete) : false;\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n    return this.buttonService.isTabVisible(tblConfig);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getVisibleFields() {\r\n    return this.formConfig.fields?.filter(x => Core.testVisible(this.formConfig, this.details, x))\r\n  }\r\n\r\n\r\n  create() {\r\n    this.handleButtonAction('create');\r\n  }\r\n\r\n  edit() {\r\n    this.handleButtonAction('edit');\r\n  }\r\n\r\n  delete() {\r\n    this.handleButtonAction('delete');\r\n  }\r\n\r\n\r\n  custom(button: Button ) {\r\n    if (button.dialog && button.detailsConfig) {\r\n      this.openNestedDetailsDialog(button);\r\n    } else {\r\n      this.handleButtonAction(button.name);\r\n    }\r\n  }\r\n\r\n  private openNestedDetailsDialog(button: Button): void {\r\n\r\n    this.dialogService.openConfiguredDetailsDialog( button.name, this.details, this.detailsConfig, DetailsDialog ).subscribe(result => {\r\n\r\n      if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result && result.message === 'success') {\r\n        this.refreshData();\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  private refreshData(): void {\r\n    if (this.formConfig.loadAction) {\r\n      this.loadData(this.formConfig.loadAction, true);\r\n    }\r\n  }\r\n\r\n  handleButtonAction(buttonName: string) {\r\n    const button = this.getButton(buttonName);\r\n    if (!button) return;\r\n\r\n    if (!button.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n    if (this.validateForm()) {\r\n      this.executeAction(button, this.details);\r\n    }\r\n  }\r\n\r\n  private validateForm(): boolean {\r\n    let validationResult = Core.validateObject(this.getVisibleFields(), this.details);\r\n    if (validationResult !== '') {\r\n      this.messageService.toast(validationResult);\r\n      return false;\r\n    }\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.formConfig.mode === 'create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return false;\r\n    }\r\n\r\n    // Validate composite fields\r\n    for (const field of this.getVisibleFields()) {\r\n      if (field.type === 'composite') {\r\n        validationResult = Core.validateObject(Core.getVisibleSubfields(this.formConfig,this.details, field), this.details);\r\n        if (validationResult !== '') {\r\n          this.messageService.toast(validationResult);\r\n          return false;\r\n        }\r\n      }\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private prepareActionData(button: Button, data: any): any {\r\n    if (button.action?.isFormData) {\r\n      const 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      formData.append(\"data\", JSON.stringify(data));\r\n      return formData;\r\n    }\r\n    return data;\r\n  }\r\n\r\n  private executeAction(button: Button, data: any) {\r\n    const actionData = this.prepareActionData(button, data);\r\n\r\n    if (button.confirm) {\r\n      this.messageService.confirm(button.confirm.message).subscribe((result) => {\r\n        if (result === \"yes\") {\r\n          this.performApiCall(button, actionData);\r\n        }\r\n      });\r\n    } else {\r\n      this.performApiCall(button, actionData);\r\n    }\r\n  }\r\n\r\n  private performApiCall(button: Button, data: any) {\r\n    this.dataService.CallApi(button.action, data).subscribe((apiResponse: ApiResponse) => {\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 if (apiResponse.message != \"success\" && apiResponse.message != \"\") {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: this.details } });\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n};\r\n\r\n\r\n\r\n","<div class=\"dialog-container\">\r\n\r\n  <div class=\"dialog-content\">\r\n\r\n    <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n    <div class=\"row d-flex align-items-center mt-0\">\r\n\r\n      <div class=\"col\">\r\n        <h2 mat-dialog-title>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n      </div>\r\n\r\n      <div class=\"col d-flex justify-content-end\">\r\n\r\n        <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n          <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n        </div>\r\n\r\n        <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n      </div>\r\n\r\n    </div>\r\n\r\n    <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n      <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\r\n\r\n      <div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n        <p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n        <spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\">\r\n          <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n            <spa-select\r\n              [display]=\"field.alias ?? field.name | camelToWords\"\r\n              [width]=\"field.width\"\r\n              [nullable]=\"field.nullable\"\r\n              [options]=\"field.options\"\r\n              [masterOptions]=\"field.masterOptions\"\r\n              [masterField]=\"field.masterField\"\r\n              [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n              [optionValue]=\"field.optionValue ?? 'value'\"\r\n              [(value)]=\"data[field.name]\"\r\n              [defaultFirstValue]=\"field.defaultFirstValue\"\r\n              [readonly]=\"testReadOnly(field)\"\r\n              [hint]=\"field.hint\"\r\n              [detailsConfig]=\"field.detailsConfig\"\r\n              [loadAction]=\"field.loadAction\"\r\n              [infoMessage]=\"field.infoMessage\"\r\n              [copyContent]=\"field.copyContent\"\r\n              (valueChange)=\"selectChanged(field)\"\r\n            ></spa-select>\r\n          </ng-template>\r\n        </spa-form>\r\n\r\n\r\n        <mat-tab-group *ngIf=\"tableConfigs\">\r\n\r\n          <ng-container *ngFor=\"let tbl of tableConfigs\">\r\n\r\n            <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n              <ng-template matTabLabel>\r\n                <span>{{tbl.title ?? 'Untitled'}}</span>\r\n              </ng-template>\r\n\r\n              <spa-table-internal [config]=\"tbl\" [hideTitle]=\"true\" [reload]=\"tableReload\" (dataLoad)=\"loadData(formConfig.loadAction, false)\"></spa-table-internal>\r\n\r\n            </mat-tab>\r\n          </ng-container>\r\n\r\n\r\n        </mat-tab-group>\r\n\r\n\r\n\r\n      </div>\r\n\r\n    </mat-dialog-content>\r\n\r\n\r\n  </div>\r\n\r\n  <mat-dialog-actions >\r\n\r\n    <div>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <ng-container *ngFor=\"let btn of extraButtons\">\r\n        <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n    </div>\r\n\r\n    <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n      <ng-container *ngFor=\"let btn of extraButtons\">\r\n        <button *ngIf=\"testVisible(details,btn.name)\" mat-icon-button matTooltipPosition=\"above\" [matTooltip]=\"btn.tip ?? btn.name | titlecase\" [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [disabled]=\"isProcessing\" style=\"color: red;\" (click)=\"delete()\" *ngIf=\"formConfig.mode!='create'  && deleteButton\"><mat-icon>delete</mat-icon></button>\r\n    </div>\r\n\r\n\r\n  </mat-dialog-actions>\r\n\r\n\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|