tin-spa 2.13.8 → 2.13.10
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 +2 -2
- package/esm2020/lib/components/alert/alert.component.mjs +6 -7
- package/esm2020/lib/components/select-common/select-common.component.mjs +8 -10
- package/esm2020/lib/components/statuses/statuses.component.mjs +1 -3
- package/esm2020/lib/components/table/detailsDialog.component.mjs +16 -4
- package/esm2020/lib/components/table-header/table-header.component.mjs +3 -3
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +16 -4
- package/esm2020/lib/components/table-lite/detailsDialog-lite.component.mjs +16 -4
- package/esm2020/lib/components/tabs/tabs.component.mjs +7 -16
- package/esm2020/lib/pages/tenant-settings/tenant-settings.component.mjs +2 -2
- package/esm2020/lib/pages/users/users.component.mjs +2 -2
- package/esm2020/lib/services/dialog.service.mjs +32 -5
- package/fesm2015/tin-spa.mjs +106 -51
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +100 -51
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +11 -2
- package/lib/components/alert/alert.component.d.ts +3 -3
- package/lib/components/table/detailsDialog.component.d.ts +4 -0
- package/lib/components/table-internal/detailsDialog-internal.component.d.ts +4 -0
- package/lib/components/table-lite/detailsDialog-lite.component.d.ts +4 -0
- package/lib/services/dialog.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -23,7 +23,7 @@ export class SecurityConfig {
|
|
|
23
23
|
}
|
|
24
24
|
export class AlertMessage {
|
|
25
25
|
}
|
|
26
|
-
export class
|
|
26
|
+
export class AlertConfig {
|
|
27
27
|
}
|
|
28
28
|
export class NotesConfig {
|
|
29
29
|
}
|
|
@@ -109,4 +109,4 @@ export class FinAccount {
|
|
|
109
109
|
this.currency = "";
|
|
110
110
|
}
|
|
111
111
|
}
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Classes.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/classes/Classes.ts"],"names":[],"mappings":"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","sourcesContent":["import { style } from \"@angular/animations\";\r\nimport { BehaviorSubject } from \"rxjs\";\r\n\r\nexport interface BitwiseOption {\r\n  name?: string;\r\n  value: number;\r\n  selected: boolean;\r\n  icon?: Icon;\r\n}\r\n\r\nexport enum RoleAccess {\r\n  None = 0,\r\n  View = 1,\r\n  Edit = 2,\r\n  Create = 3,\r\n  Full = 4\r\n}\r\n\r\nexport enum DetailsSource {Row, Url}\r\n\r\nexport class dialogOptions {\r\n  width?: string;\r\n  height?: string;\r\n}\r\n\r\nexport class DetailsDialogConfig {\r\n\r\n  stepConfig? : StepConfig;\r\n  statusConfig? : StatusConfig;\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  detailsSource?: DetailsSource\r\n  options?: dialogOptions\r\n  autoRefreshConfig?: AutoRefreshConfig;\r\n  refreshOnClose?: boolean;\r\n  causeTableRefresh?: boolean;\r\n}\r\n\r\n\r\n\r\nexport class Action{\r\n  method?: 'get' | 'post'\r\n  url: string;\r\n  params? : any[]\r\n  successMessage?: string\r\n  isFormData?: boolean\r\n  skipCache?: boolean\r\n}\r\n\r\n\r\nexport interface SearchField extends Field {\r\n  show?: boolean\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\n\r\n\r\nexport class SecurityConfig {\r\n  allow?: CapItem[];\r\n  deny?: CapItem[];\r\n}\r\n\r\nexport interface ChildField {\r\n  childField?: string\r\n  childValueField?: string\r\n}\r\n\r\nexport interface AutoRefreshConfig {\r\n  // Time between refreshes in milliseconds (default: 5000ms = 5 seconds)\r\n  interval?: number;\r\n  stopCondition?: (data: any) => boolean;\r\n  defaultOn?: boolean;\r\n}\r\n\r\n\r\nexport interface Field {\r\n  securityConfig?: SecurityConfig;\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' | 'html';\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  requiredCondition?: (value: any) => 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' | 'number'\r\n  hideOnCreate?: boolean\r\n  hideOnExists?: boolean\r\n  hiddenCondition?: (value: any) => boolean;\r\n  readonlyCondition?: (value: any) => boolean;\r\n  detailsConfig?: DetailsDialogConfig;\r\n  loadAction?: Action\r\n  loadIDField?: string;\r\n  infoMessage?: string;\r\n  suffix?: string;\r\n  subfields?: Field[];\r\n  optionsSubject?: BehaviorSubject<any[]>;\r\n  section?: string;\r\n  fileOptions?: {\r\n    allowedExtensions?: string[];\r\n    maxSizeMB?: number;\r\n    compressImages?: boolean;\r\n  };\r\n  collapsed?: boolean;\r\n  collapsedCondition?: (value: any) => boolean;\r\n  maxHeight?: string;\r\n  valueCalculation?: (value: any) => any;\r\n}\r\n\r\nexport interface StatusState {\r\n  condition: (data: any) => boolean;\r\n  icon: string;                        \r\n  color: string;                       \r\n}\r\n\r\nexport interface StatusItem {\r\n  name: string;\r\n  hiddenCondition?: (data: any) => boolean;\r\n  states: StatusState[];\r\n}\r\n\r\n// StatusConfig remains the same\r\nexport interface StatusConfig {\r\n  items: StatusItem[];\r\n  hiddenCondition?: (data: any) => boolean;\r\n}\r\n\r\n\r\nexport class AlertMessage {\r\n  type?: 'success' | 'info' | 'warn' | 'critical'\r\n  content?: string  // Changed: Made optional since we might use contentField instead\r\n  contentField?: string  // Changed: New property to dynamically pull content from data\r\n  hiddenCondition?: (value: any) => boolean;\r\n  showCondition?: (value: any) => boolean;\r\n}\r\n\r\nexport class AlertMessages {\r\n  subject?: string\r\n  compact? : boolean\r\n  messages: AlertMessage[]\r\n}\r\n\r\nexport class NotesConfig {\r\n  title?: string;\r\n  loadAction?: Action;\r\n  loadIDField?: string;\r\n  notes?: any[]; // Direct notes data array\r\n  nameField?: string; // Field mapping for name/author\r\n  dateField?: string; // Field mapping for date/timestamp\r\n  commentField?: string; // Field mapping for comment/content\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  loadAction?: Action\r\n  heroField?: any\r\n  heroValue?: any\r\n  security?: SecurityConfig;\r\n  includeAudit?: boolean\r\n  notesConfig?: NotesConfig;\r\n}\r\n\r\nexport interface Confirm {\r\n  message?: string\r\n  func?: (data: any) => string; \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  ignorePendingApproval?: boolean;\r\n  keepOpen?: boolean;\r\n  onSuccess?: (response: ApiResponse, details: any) => void;\r\n  onClick?: (details: any) => void;\r\n  editOnSuccess?: boolean\r\n  onSuccessButton?: Button\r\n}\r\n\r\n\r\nexport interface CapsuleConfig {\r\n  displayField: string;\r\n  leftIcons?: Icon[];\r\n  rightIcons?: Icon[];\r\n  // buttons?: Button[];\r\n  loadAction?: Action;\r\n}\r\n\r\nexport interface CardConfig {\r\n  imageField?: string;\r\n  titleField: string;\r\n  subtitleField?: string;\r\n  contentFields: string[];\r\n  columns?: number;\r\n  elevation?: 'low' | 'medium' | 'high';\r\n}\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  hiddenCondition?: (value: any) => boolean;\r\n}\r\nexport class TileConfig {\r\n  tiles: Tile[]\r\n  loadAction?: Action\r\n  loadInit?: boolean\r\n  clickable?: boolean\r\n  headerPosition?: | 'top' | 'middle';\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\nexport class StepConfig {\r\n  steps: Step[]\r\n  valueField?: string\r\n  loadAction?: Action;\r\n  loadIDField?: string\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\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  maxLength?: 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\n\r\nexport type TableViewType = 'table' | 'capsule' | 'card';\r\nexport class TableConfig{\r\n  viewType?: TableViewType \r\n  capsuleConfig?: CapsuleConfig\r\n  cardConfig?: CardConfig\r\n  tabTitle?: 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  countAction?: Action\r\n  loadIDField ?: string\r\n  loadCriteria?: string\r\n  lazyLoad?: boolean\r\n  causeFormRefresh?: boolean\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  maxButtonsCount?: 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 class PageConfig {\r\n  title?: string;\r\n  tableConfig?: TableConfig;\r\n  searchTableConfig?: TableConfig;\r\n}\r\n\r\n\r\n\r\n\r\n//---Base---\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 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    this.color = \"black\";\r\n    this.isBool = false;\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  color: string;\r\n  isBool : boolean;\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.microsoftAuth = false;\r\n    this.microsoftAuthMessage = \"Sign in with Microsoft\";\r\n    this.selfService = false;\r\n    this.multitenant = false;\r\n    this.navigation = 'top';\r\n    this.progressLine = false;\r\n    this.loginStyle = 'default';\r\n    this.termsUrl = \"https://yoursite.com/terms\";\r\n    this.privacyUrl = \"https://yoursite.com/privacy\";\r\n    this.siteUrl = \"https://yoursite.com\";\r\n    this.navWidth = '200px';\r\n\r\n  }\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  microsoftAuth: boolean;\r\n  microsoftAuthMessage: string;\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  loginStyle : string;\r\n  loginTitle : string;\r\n  loginMessage : string;\r\n  termsUrl: string;\r\n  privacyUrl: string;\r\n  siteUrl: string;\r\n  navWidth: string;\r\n\r\n}\r\n\r\n\r\n\r\n\r\n//-----------Move out------\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"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Classes.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/classes/Classes.ts"],"names":[],"mappings":"AASA,MAAM,CAAN,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,2CAAQ,CAAA;IACR,2CAAQ,CAAA;IACR,2CAAQ,CAAA;IACR,+CAAU,CAAA;IACV,2CAAQ,CAAA;AACV,CAAC,EANW,UAAU,KAAV,UAAU,QAMrB;AAED,MAAM,CAAN,IAAY,aAAwB;AAApC,WAAY,aAAa;IAAE,+CAAG,CAAA;IAAE,+CAAG,CAAA;AAAA,CAAC,EAAxB,aAAa,KAAb,aAAa,QAAW;AAEpC,MAAM,OAAO,aAAa;CAGzB;AAOD,MAAM,OAAO,mBAAmB;CAmB/B;AAID,MAAM,OAAO,MAAM;CAOlB;AAOD,MAAM,OAAO,YAAY;CAKxB;AAID,MAAM,OAAO,cAAc;CAG1B;AA0FD,MAAM,OAAO,YAAY;CAMxB;AAED,MAAM,OAAO,WAAW;CAKvB;AAED,MAAM,OAAO,WAAW;CAQvB;AAED,MAAM,OAAO,UAAU;CAetB;AA+DD,MAAM,OAAO,UAAU;CAMtB;AAED,MAAM,OAAO,IAAI;CAKhB;AACD,MAAM,OAAO,UAAU;CAMtB;AAkCD,MAAM,OAAO,WAAW;CAsCvB;AAED,MAAM,OAAO,UAAU;CAItB;AAKD,YAAY;AAEZ,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,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;QAC5B,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IAEtB,CAAC;CAgBF;AAED,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,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,oBAAoB,GAAG,wBAAwB,CAAC;QACrD,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;QAC1B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,4BAA4B,CAAC;QAC7C,IAAI,CAAC,UAAU,GAAG,8BAA8B,CAAC;QACjD,IAAI,CAAC,OAAO,GAAG,sBAAsB,CAAC;QACtC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;IAE1B,CAAC;CAwBF;AAKD,2BAA2B;AAC3B,MAAM,OAAO,WAAW;IAEtB;QACE,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IACtB,CAAC;CAWF;AAED,MAAM,OAAO,UAAU;IAErB;QACE,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IAErB,CAAC;CAQF","sourcesContent":["import { BehaviorSubject } from \"rxjs\";\r\n\r\nexport interface BitwiseOption {\r\n  name?: string;\r\n  value: number;\r\n  selected: boolean;\r\n  icon?: Icon;\r\n}\r\n\r\nexport enum RoleAccess {\r\n  None = 0,\r\n  View = 1,\r\n  Edit = 2,\r\n  Create = 3,\r\n  Full = 4\r\n}\r\n\r\nexport enum DetailsSource {Row, Url}\r\n\r\nexport class dialogOptions {\r\n  width?: string;\r\n  height?: string;\r\n}\r\n\r\nexport interface CloseOptions {\r\n  position?: 'top' | 'bottom'; // Default: 'bottom'\r\n  text?: string; // Default: 'Cancel' - only applies when position is 'bottom'\r\n}\r\n\r\nexport class DetailsDialogConfig {\r\n\r\n  stepConfig? : StepConfig;\r\n  statusConfig? : StatusConfig;\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  detailsSource?: DetailsSource\r\n  options?: dialogOptions\r\n  autoRefreshConfig?: AutoRefreshConfig;\r\n  refreshOnClose?: boolean;\r\n  causeTableRefresh?: boolean;\r\n  closeOptions?: CloseOptions;\r\n}\r\n\r\n\r\n\r\nexport class Action{\r\n  method?: 'get' | 'post'\r\n  url: string;\r\n  params? : any[]\r\n  successMessage?: string\r\n  isFormData?: boolean\r\n  skipCache?: boolean\r\n}\r\n\r\n\r\nexport interface SearchField extends Field {\r\n  show?: boolean\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\n\r\n\r\nexport class SecurityConfig {\r\n  allow?: CapItem[];\r\n  deny?: CapItem[];\r\n}\r\n\r\nexport interface ChildField {\r\n  childField?: string\r\n  childValueField?: string\r\n}\r\n\r\nexport interface AutoRefreshConfig {\r\n  // Time between refreshes in milliseconds (default: 5000ms = 5 seconds)\r\n  interval?: number;\r\n  stopCondition?: (data: any) => boolean;\r\n  defaultOn?: boolean;\r\n}\r\n\r\n\r\nexport interface Field {\r\n  securityConfig?: SecurityConfig;\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' | 'html';\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  requiredCondition?: (value: any) => 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' | 'number'\r\n  hideOnCreate?: boolean\r\n  hideOnExists?: boolean\r\n  hiddenCondition?: (value: any) => boolean;\r\n  readonlyCondition?: (value: any) => boolean;\r\n  detailsConfig?: DetailsDialogConfig;\r\n  loadAction?: Action\r\n  loadIDField?: string;\r\n  infoMessage?: string;\r\n  suffix?: string;\r\n  subfields?: Field[];\r\n  optionsSubject?: BehaviorSubject<any[]>;\r\n  section?: string;\r\n  fileOptions?: {\r\n    allowedExtensions?: string[];\r\n    maxSizeMB?: number;\r\n    compressImages?: boolean;\r\n  };\r\n  collapsed?: boolean;\r\n  collapsedCondition?: (value: any) => boolean;\r\n  maxHeight?: string;\r\n  valueCalculation?: (value: any) => any;\r\n}\r\n\r\nexport interface StatusState {\r\n  condition: (data: any) => boolean;\r\n  icon: string;                        \r\n  color: string;                       \r\n}\r\n\r\nexport interface StatusItem {\r\n  name: string;\r\n  hiddenCondition?: (data: any) => boolean;\r\n  states: StatusState[];\r\n}\r\n\r\nexport interface StatusConfig {\r\n  items: StatusItem[];\r\n  sticky?: boolean;\r\n  hiddenCondition?: (data: any) => boolean;\r\n}\r\n\r\n\r\nexport class AlertMessage {\r\n  type?: 'success' | 'info' | 'warn' | 'critical'\r\n  content?: string \r\n  contentField?: string\r\n  hiddenCondition?: (value: any) => boolean;\r\n  showCondition?: (value: any) => boolean;\r\n}\r\n\r\nexport class AlertConfig {\r\n  subject?: string\r\n  compact? : boolean\r\n  sticky?: boolean \r\n  messages: AlertMessage[]\r\n}\r\n\r\nexport class NotesConfig {\r\n  title?: string;\r\n  loadAction?: Action;\r\n  loadIDField?: string;\r\n  notes?: any[];\r\n  nameField?: string;\r\n  dateField?: string;\r\n  commentField?: string;\r\n}\r\n\r\nexport class FormConfig {\r\n  title?: string\r\n  fixedTitle?: boolean\r\n  alertConfig?: AlertConfig\r\n  fields: Field[]\r\n  mode?: 'create' | 'edit' | 'view'\r\n  button? : Button\r\n  multiColumn?: boolean\r\n  reset?: boolean\r\n  loadAction?: Action\r\n  heroField?: any\r\n  heroValue?: any\r\n  security?: SecurityConfig;\r\n  includeAudit?: boolean\r\n  notesConfig?: NotesConfig;\r\n}\r\n\r\nexport interface Confirm {\r\n  message?: string\r\n  func?: (data: any) => string; \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  ignorePendingApproval?: boolean;\r\n  keepOpen?: boolean;\r\n  onSuccess?: (response: ApiResponse, details: any) => void;\r\n  onClick?: (details: any) => void;\r\n  editOnSuccess?: boolean\r\n  onSuccessButton?: Button\r\n  skipValidation?: boolean\r\n}\r\n\r\n\r\nexport interface CapsuleConfig {\r\n  displayField: string;\r\n  leftIcons?: Icon[];\r\n  rightIcons?: Icon[];\r\n  // buttons?: Button[];\r\n  loadAction?: Action;\r\n}\r\n\r\nexport interface CardConfig {\r\n  imageField?: string;\r\n  titleField: string;\r\n  subtitleField?: string;\r\n  contentFields: string[];\r\n  columns?: number;\r\n  elevation?: 'low' | 'medium' | 'high';\r\n}\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  hiddenCondition?: (value: any) => boolean;\r\n}\r\nexport class TileConfig {\r\n  tiles: Tile[]\r\n  loadAction?: Action\r\n  loadInit?: boolean\r\n  clickable?: boolean\r\n  headerPosition?: | 'top' | 'middle';\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\nexport class StepConfig {\r\n  steps: Step[]\r\n  valueField?: string\r\n  loadAction?: Action;\r\n  loadIDField?: string;\r\n  sticky?: 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\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  maxLength?: 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\n\r\nexport type TableViewType = 'table' | 'capsule' | 'card';\r\nexport class TableConfig{\r\n  viewType?: TableViewType \r\n  capsuleConfig?: CapsuleConfig\r\n  cardConfig?: CardConfig\r\n  tabTitle?: 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  countAction?: Action\r\n  loadIDField ?: string\r\n  loadCriteria?: string\r\n  lazyLoad?: boolean\r\n  causeFormRefresh?: boolean\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  maxButtonsCount?: 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 class PageConfig {\r\n  title?: string;\r\n  tableConfig?: TableConfig;\r\n  searchTableConfig?: TableConfig;\r\n}\r\n\r\n\r\n\r\n\r\n//---Base---\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 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    this.color = \"black\";\r\n    this.isBool = false;\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  color: string;\r\n  isBool : boolean;\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.microsoftAuth = false;\r\n    this.microsoftAuthMessage = \"Sign in with Microsoft\";\r\n    this.selfService = false;\r\n    this.multitenant = false;\r\n    this.navigation = 'top';\r\n    this.progressLine = false;\r\n    this.loginStyle = 'default';\r\n    this.termsUrl = \"https://yoursite.com/terms\";\r\n    this.privacyUrl = \"https://yoursite.com/privacy\";\r\n    this.siteUrl = \"https://yoursite.com\";\r\n    this.navWidth = '200px';\r\n\r\n  }\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  microsoftAuth: boolean;\r\n  microsoftAuthMessage: string;\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  loginStyle : string;\r\n  loginTitle : string;\r\n  loginMessage : string;\r\n  termsUrl: string;\r\n  privacyUrl: string;\r\n  siteUrl: string;\r\n  navWidth: string;\r\n\r\n}\r\n\r\n\r\n\r\n\r\n//-----------Move out------\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"]}
|
|
@@ -6,12 +6,12 @@ export class AlertComponent {
|
|
|
6
6
|
ngOnInit() {
|
|
7
7
|
}
|
|
8
8
|
getAlertMessages(type = undefined) {
|
|
9
|
-
return this.
|
|
9
|
+
return this.config?.messages
|
|
10
10
|
.filter(x => this.testVisible(x))
|
|
11
11
|
.filter(x => x.type === type) || [];
|
|
12
12
|
}
|
|
13
13
|
hasAlertMessages(type = undefined) {
|
|
14
|
-
return this.
|
|
14
|
+
return this.config?.messages
|
|
15
15
|
.filter(x => this.testVisible(x))
|
|
16
16
|
.some(x => x.type === type) || false;
|
|
17
17
|
}
|
|
@@ -21,7 +21,6 @@ export class AlertComponent {
|
|
|
21
21
|
}
|
|
22
22
|
return msg.hiddenCondition ? !msg.hiddenCondition(this.data) : true;
|
|
23
23
|
}
|
|
24
|
-
// Changed: New method to get the content dynamically
|
|
25
24
|
getMessageContent(msg) {
|
|
26
25
|
// If contentField is specified and data exists, use dynamic content
|
|
27
26
|
if (msg.contentField && this.data && this.data[msg.contentField]) {
|
|
@@ -32,13 +31,13 @@ export class AlertComponent {
|
|
|
32
31
|
}
|
|
33
32
|
}
|
|
34
33
|
AlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
35
|
-
AlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AlertComponent, selector: "spa-alert", inputs: {
|
|
34
|
+
AlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AlertComponent, selector: "spa-alert", inputs: { config: "config", data: "data" }, ngImport: i0, template: "<div *ngIf=\"hasAlertMessages()\" class=\"alert alert-secondary\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages(); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('success')\" class=\"alert alert-success\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('success'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('info')\" class=\"alert alert-info\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('info'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('warn')\" class=\"alert alert-warning\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('warn'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('critical')\" class=\"alert alert-danger\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('critical'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n", styles: [".alert-compact{padding-top:7px;padding-bottom:7px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
36
35
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AlertComponent, decorators: [{
|
|
37
36
|
type: Component,
|
|
38
|
-
args: [{ selector: 'spa-alert', template: "<div *ngIf=\"hasAlertMessages()\" class=\"alert alert-secondary\" [ngClass]=\"{'alert-compact':
|
|
39
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
37
|
+
args: [{ selector: 'spa-alert', template: "<div *ngIf=\"hasAlertMessages()\" class=\"alert alert-secondary\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages(); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('success')\" class=\"alert alert-success\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('success'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('info')\" class=\"alert alert-info\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('info'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('warn')\" class=\"alert alert-warning\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('warn'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"hasAlertMessages('critical')\" class=\"alert alert-danger\" [ngClass]=\"{'alert-compact': config.compact}\" style=\"font-size: 14px;margin-bottom: 5px;\" role=\"alert\">\r\n <p *ngIf=\"config.subject\">{{config.subject}}</p>\r\n <ng-container *ngFor=\"let msg of getAlertMessages('critical'); let last = last\">\r\n <label *ngIf=\"testVisible(msg)\">{{getMessageContent(msg)}}</label>\r\n <br *ngIf=\"!last\">\r\n </ng-container>\r\n</div>\r\n", styles: [".alert-compact{padding-top:7px;padding-bottom:7px}\n"] }]
|
|
38
|
+
}], ctorParameters: function () { return []; }, propDecorators: { config: [{
|
|
40
39
|
type: Input
|
|
41
40
|
}], data: [{
|
|
42
41
|
type: Input
|
|
43
42
|
}] } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7OztBQVF6RCxNQUFNLE9BQU8sY0FBYztJQUV6QixnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQztJQU9ELGdCQUFnQixDQUFDLElBQUksR0FBRyxTQUFTO1FBQy9CLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxRQUFRO2FBQ3pCLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDaEMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDeEMsQ0FBQztJQUVELGdCQUFnQixDQUFDLElBQUksR0FBRyxTQUFTO1FBQy9CLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxRQUFRO2FBQ3pCLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDaEMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxJQUFJLENBQUMsSUFBSSxLQUFLLENBQUM7SUFDekMsQ0FBQztJQUVELFdBQVcsQ0FBQyxHQUFpQjtRQUUzQixJQUFJLEdBQUcsQ0FBQyxhQUFhLEVBQUU7WUFDckIsT0FBTyxHQUFHLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNyQztRQUVELE9BQU8sR0FBRyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBRXRFLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxHQUFpQjtRQUNqQyxvRUFBb0U7UUFDcEUsSUFBSSxHQUFHLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLEVBQUU7WUFDaEUsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsQ0FBQztTQUNwQztRQUVELDhCQUE4QjtRQUM5QixPQUFPLEdBQUcsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO0lBQzNCLENBQUM7OzJHQTFDVSxjQUFjOytGQUFkLGNBQWMsNkZDUjNCLHd3RUF3Q0E7MkZEaENhLGNBQWM7a0JBTDFCLFNBQVM7K0JBQ0UsV0FBVzswRUFZWixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFsZXJ0TWVzc2FnZSwgQWxlcnRDb25maWcgfSBmcm9tICcuLi8uLi9jbGFzc2VzL0NsYXNzZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtYWxlcnQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9hbGVydC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vYWxlcnQuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBbGVydENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gIH1cclxuXHJcblxyXG4gIEBJbnB1dCgpIGNvbmZpZzogQWxlcnRDb25maWc7XHJcbiAgQElucHV0KCkgZGF0YTtcclxuXHJcblxyXG4gIGdldEFsZXJ0TWVzc2FnZXModHlwZSA9IHVuZGVmaW5lZCk6IEFsZXJ0TWVzc2FnZVtdIHtcclxuICAgIHJldHVybiB0aGlzLmNvbmZpZz8ubWVzc2FnZXNcclxuICAgICAgLmZpbHRlcih4ID0+IHRoaXMudGVzdFZpc2libGUoeCkpXHJcbiAgICAgIC5maWx0ZXIoeCA9PiB4LnR5cGUgPT09IHR5cGUpIHx8IFtdO1xyXG4gIH1cclxuXHJcbiAgaGFzQWxlcnRNZXNzYWdlcyh0eXBlID0gdW5kZWZpbmVkKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5jb25maWc/Lm1lc3NhZ2VzXHJcbiAgICAgIC5maWx0ZXIoeCA9PiB0aGlzLnRlc3RWaXNpYmxlKHgpKVxyXG4gICAgICAuc29tZSh4ID0+IHgudHlwZSA9PT0gdHlwZSkgfHwgZmFsc2U7XHJcbiAgfVxyXG5cclxuICB0ZXN0VmlzaWJsZShtc2c6IEFsZXJ0TWVzc2FnZSk6IGJvb2xlYW4ge1xyXG5cclxuICAgIGlmIChtc2cuc2hvd0NvbmRpdGlvbikge1xyXG4gICAgICByZXR1cm4gbXNnLnNob3dDb25kaXRpb24odGhpcy5kYXRhKTtcclxuICAgIH1cclxuICAgIFxyXG4gICAgcmV0dXJuIG1zZy5oaWRkZW5Db25kaXRpb24gPyAhbXNnLmhpZGRlbkNvbmRpdGlvbih0aGlzLmRhdGEpIDogdHJ1ZTtcclxuXHJcbiAgfVxyXG5cclxuICBnZXRNZXNzYWdlQ29udGVudChtc2c6IEFsZXJ0TWVzc2FnZSk6IHN0cmluZyB7XHJcbiAgICAvLyBJZiBjb250ZW50RmllbGQgaXMgc3BlY2lmaWVkIGFuZCBkYXRhIGV4aXN0cywgdXNlIGR5bmFtaWMgY29udGVudFxyXG4gICAgaWYgKG1zZy5jb250ZW50RmllbGQgJiYgdGhpcy5kYXRhICYmIHRoaXMuZGF0YVttc2cuY29udGVudEZpZWxkXSkge1xyXG4gICAgICByZXR1cm4gdGhpcy5kYXRhW21zZy5jb250ZW50RmllbGRdO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICAvLyBGYWxsIGJhY2sgdG8gc3RhdGljIGNvbnRlbnRcclxuICAgIHJldHVybiBtc2cuY29udGVudCB8fCAnJztcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgKm5nSWY9XCJoYXNBbGVydE1lc3NhZ2VzKClcIiBjbGFzcz1cImFsZXJ0IGFsZXJ0LXNlY29uZGFyeVwiIFtuZ0NsYXNzXT1cInsnYWxlcnQtY29tcGFjdCc6IGNvbmZpZy5jb21wYWN0fVwiIHN0eWxlPVwiZm9udC1zaXplOiAxNHB4O21hcmdpbi1ib3R0b206IDVweDtcIiByb2xlPVwiYWxlcnRcIj5cclxuICA8cCAqbmdJZj1cImNvbmZpZy5zdWJqZWN0XCI+e3tjb25maWcuc3ViamVjdH19PC9wPlxyXG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IG1zZyBvZiBnZXRBbGVydE1lc3NhZ2VzKCk7IGxldCBsYXN0ID0gbGFzdFwiPlxyXG4gICAgPGxhYmVsICpuZ0lmPVwidGVzdFZpc2libGUobXNnKVwiPnt7Z2V0TWVzc2FnZUNvbnRlbnQobXNnKX19PC9sYWJlbD5cclxuICAgIDxiciAqbmdJZj1cIiFsYXN0XCI+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvZGl2PlxyXG5cclxuPGRpdiAqbmdJZj1cImhhc0FsZXJ0TWVzc2FnZXMoJ3N1Y2Nlc3MnKVwiIGNsYXNzPVwiYWxlcnQgYWxlcnQtc3VjY2Vzc1wiIFtuZ0NsYXNzXT1cInsnYWxlcnQtY29tcGFjdCc6IGNvbmZpZy5jb21wYWN0fVwiIHN0eWxlPVwiZm9udC1zaXplOiAxNHB4O21hcmdpbi1ib3R0b206IDVweDtcIiByb2xlPVwiYWxlcnRcIj5cclxuICA8cCAqbmdJZj1cImNvbmZpZy5zdWJqZWN0XCI+e3tjb25maWcuc3ViamVjdH19PC9wPlxyXG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IG1zZyBvZiBnZXRBbGVydE1lc3NhZ2VzKCdzdWNjZXNzJyk7IGxldCBsYXN0ID0gbGFzdFwiPlxyXG4gICAgPGxhYmVsICpuZ0lmPVwidGVzdFZpc2libGUobXNnKVwiPnt7Z2V0TWVzc2FnZUNvbnRlbnQobXNnKX19PC9sYWJlbD5cclxuICAgIDxiciAqbmdJZj1cIiFsYXN0XCI+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvZGl2PlxyXG5cclxuPGRpdiAqbmdJZj1cImhhc0FsZXJ0TWVzc2FnZXMoJ2luZm8nKVwiIGNsYXNzPVwiYWxlcnQgYWxlcnQtaW5mb1wiIFtuZ0NsYXNzXT1cInsnYWxlcnQtY29tcGFjdCc6IGNvbmZpZy5jb21wYWN0fVwiIHN0eWxlPVwiZm9udC1zaXplOiAxNHB4O21hcmdpbi1ib3R0b206IDVweDtcIiByb2xlPVwiYWxlcnRcIj5cclxuICA8cCAqbmdJZj1cImNvbmZpZy5zdWJqZWN0XCI+e3tjb25maWcuc3ViamVjdH19PC9wPlxyXG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IG1zZyBvZiBnZXRBbGVydE1lc3NhZ2VzKCdpbmZvJyk7IGxldCBsYXN0ID0gbGFzdFwiPlxyXG4gICAgPGxhYmVsICpuZ0lmPVwidGVzdFZpc2libGUobXNnKVwiPnt7Z2V0TWVzc2FnZUNvbnRlbnQobXNnKX19PC9sYWJlbD5cclxuICAgIDxiciAqbmdJZj1cIiFsYXN0XCI+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcblxyXG48L2Rpdj5cclxuXHJcbjxkaXYgKm5nSWY9XCJoYXNBbGVydE1lc3NhZ2VzKCd3YXJuJylcIiBjbGFzcz1cImFsZXJ0IGFsZXJ0LXdhcm5pbmdcIiBbbmdDbGFzc109XCJ7J2FsZXJ0LWNvbXBhY3QnOiBjb25maWcuY29tcGFjdH1cIiBzdHlsZT1cImZvbnQtc2l6ZTogMTRweDttYXJnaW4tYm90dG9tOiA1cHg7XCIgcm9sZT1cImFsZXJ0XCI+XHJcbiAgPHAgKm5nSWY9XCJjb25maWcuc3ViamVjdFwiPnt7Y29uZmlnLnN1YmplY3R9fTwvcD5cclxuICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBtc2cgb2YgZ2V0QWxlcnRNZXNzYWdlcygnd2FybicpOyBsZXQgbGFzdCA9IGxhc3RcIj5cclxuICAgIDxsYWJlbCAqbmdJZj1cInRlc3RWaXNpYmxlKG1zZylcIj57e2dldE1lc3NhZ2VDb250ZW50KG1zZyl9fTwvbGFiZWw+XHJcbiAgICA8YnIgKm5nSWY9XCIhbGFzdFwiPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG48L2Rpdj5cclxuXHJcbjxkaXYgKm5nSWY9XCJoYXNBbGVydE1lc3NhZ2VzKCdjcml0aWNhbCcpXCIgY2xhc3M9XCJhbGVydCBhbGVydC1kYW5nZXJcIiBbbmdDbGFzc109XCJ7J2FsZXJ0LWNvbXBhY3QnOiBjb25maWcuY29tcGFjdH1cIiBzdHlsZT1cImZvbnQtc2l6ZTogMTRweDttYXJnaW4tYm90dG9tOiA1cHg7XCIgcm9sZT1cImFsZXJ0XCI+XHJcbiAgPHAgKm5nSWY9XCJjb25maWcuc3ViamVjdFwiPnt7Y29uZmlnLnN1YmplY3R9fTwvcD5cclxuICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBtc2cgb2YgZ2V0QWxlcnRNZXNzYWdlcygnY3JpdGljYWwnKTsgbGV0IGxhc3QgPSBsYXN0XCI+XHJcbiAgICA8bGFiZWwgKm5nSWY9XCJ0ZXN0VmlzaWJsZShtc2cpXCI+e3tnZXRNZXNzYWdlQ29udGVudChtc2cpfX08L2xhYmVsPlxyXG4gICAgPGJyICpuZ0lmPVwiIWxhc3RcIj5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -16,7 +16,7 @@ export class SelectCommonComponent {
|
|
|
16
16
|
this.messageService = messageService;
|
|
17
17
|
this.dataService = dataService;
|
|
18
18
|
this.isHovered = false;
|
|
19
|
-
this.selectedOptionHint = "";
|
|
19
|
+
this.selectedOptionHint = "";
|
|
20
20
|
this.width = "100%";
|
|
21
21
|
this.readonly = false;
|
|
22
22
|
this.required = true;
|
|
@@ -43,7 +43,7 @@ export class SelectCommonComponent {
|
|
|
43
43
|
this.subscription = this.field.optionsSubject.subscribe(newOptions => {
|
|
44
44
|
if (newOptions) {
|
|
45
45
|
this.options = newOptions;
|
|
46
|
-
this.updateSelectedOptionHint();
|
|
46
|
+
this.updateSelectedOptionHint();
|
|
47
47
|
}
|
|
48
48
|
});
|
|
49
49
|
}
|
|
@@ -56,7 +56,7 @@ export class SelectCommonComponent {
|
|
|
56
56
|
if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {
|
|
57
57
|
this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: "None" });
|
|
58
58
|
}
|
|
59
|
-
this.updateSelectedOptionHint();
|
|
59
|
+
this.updateSelectedOptionHint();
|
|
60
60
|
}
|
|
61
61
|
setDefaultValue() {
|
|
62
62
|
if (this.defaultFirstValue && this.options && this.options.length > 0 &&
|
|
@@ -67,9 +67,8 @@ export class SelectCommonComponent {
|
|
|
67
67
|
}
|
|
68
68
|
changed() {
|
|
69
69
|
this.valueChange.emit(this.value);
|
|
70
|
-
this.updateSelectedOptionHint();
|
|
70
|
+
this.updateSelectedOptionHint();
|
|
71
71
|
}
|
|
72
|
-
// Changed: Added method to update hint based on selected option
|
|
73
72
|
updateSelectedOptionHint() {
|
|
74
73
|
if (!this.options || this.options.length === 0 || this.value == null || this.value == undefined) {
|
|
75
74
|
this.selectedOptionHint = this.hint; // Fall back to component hint
|
|
@@ -83,7 +82,6 @@ export class SelectCommonComponent {
|
|
|
83
82
|
this.selectedOptionHint = this.hint; // Fall back to component hint
|
|
84
83
|
}
|
|
85
84
|
}
|
|
86
|
-
// Changed: Added getter for computed hint to use in template
|
|
87
85
|
get computedHint() {
|
|
88
86
|
return this.selectedOptionHint || this.hint;
|
|
89
87
|
}
|
|
@@ -139,7 +137,7 @@ export class SelectCommonComponent {
|
|
|
139
137
|
this.field.optionsSubject.next(apiResponse.data);
|
|
140
138
|
}
|
|
141
139
|
}
|
|
142
|
-
this.updateSelectedOptionHint();
|
|
140
|
+
this.updateSelectedOptionHint();
|
|
143
141
|
}
|
|
144
142
|
});
|
|
145
143
|
}
|
|
@@ -150,10 +148,10 @@ export class SelectCommonComponent {
|
|
|
150
148
|
}
|
|
151
149
|
}
|
|
152
150
|
SelectCommonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectCommonComponent, deps: [{ token: i1.MessageService }, { token: i2.DataServiceLib }], target: i0.ɵɵFactoryTarget.Component });
|
|
153
|
-
SelectCommonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectCommonComponent, selector: "spa-select-common", inputs: { width: "width", readonly: "readonly", required: "required", defaultFirstValue: "defaultFirstValue", readonlyMode: "readonlyMode", hint: "hint", placeholder: "placeholder", multiple: "multiple", display: "display", value: "value", options: "options", masterOptions: "masterOptions", masterField: "masterField", optionValue: "optionValue", optionDisplay: "optionDisplay", optionDisplayExtra: "optionDisplayExtra", nullable: "nullable", infoMessage: "infoMessage", copyContent: "copyContent", loadAction: "loadAction", loadIDField: "loadIDField", field: "field", data: "data" }, outputs: { valueChange: "valueChange", hoverChange: "hoverChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"computedHint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"
|
|
151
|
+
SelectCommonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectCommonComponent, selector: "spa-select-common", inputs: { width: "width", readonly: "readonly", required: "required", defaultFirstValue: "defaultFirstValue", readonlyMode: "readonlyMode", hint: "hint", placeholder: "placeholder", multiple: "multiple", display: "display", value: "value", options: "options", masterOptions: "masterOptions", masterField: "masterField", optionValue: "optionValue", optionDisplay: "optionDisplay", optionDisplayExtra: "optionDisplayExtra", nullable: "nullable", infoMessage: "infoMessage", copyContent: "copyContent", loadAction: "loadAction", loadIDField: "loadIDField", field: "field", data: "data" }, outputs: { valueChange: "valueChange", hoverChange: "hoverChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"computedHint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"false\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n <mat-label>{{display}}</mat-label>\r\n <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\" [required]=\"required\">\r\n <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n </mat-option>\r\n </mat-select>\r\n\r\n <div matSuffix class=\"suffix-icons\">\r\n <ng-content select=\"[additionalButtons]\"></ng-content>\r\n <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">cached</mat-icon>\r\n </button>\r\n <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n </div>\r\n\r\n</mat-form-field>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix]" }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i10.SuffixComponent, selector: "spa-suffix", inputs: ["label", "infoMessage", "copyContent", "isHovered", "clearContent", "value"], outputs: ["infoClick", "copyClick", "clearClick", "valueChange"] }] });
|
|
154
152
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectCommonComponent, decorators: [{
|
|
155
153
|
type: Component,
|
|
156
|
-
args: [{ selector: 'spa-select-common', template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"computedHint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"
|
|
154
|
+
args: [{ selector: 'spa-select-common', template: "<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"computedHint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"false\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n <mat-label>{{display}}</mat-label>\r\n <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\" [required]=\"required\">\r\n <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n </mat-option>\r\n </mat-select>\r\n\r\n <div matSuffix class=\"suffix-icons\">\r\n <ng-content select=\"[additionalButtons]\"></ng-content>\r\n <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n <mat-icon color=\"primary\">cached</mat-icon>\r\n </button>\r\n <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n </div>\r\n\r\n</mat-form-field>\r\n", styles: [".suffix-icons{display:flex;align-items:center}.suffix-icons button{opacity:0;transition:opacity .3s ease}:host:hover .suffix-icons button{opacity:1}\n"] }]
|
|
157
155
|
}], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }]; }, propDecorators: { width: [{
|
|
158
156
|
type: Input
|
|
159
157
|
}], readonly: [{
|
|
@@ -205,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
205
203
|
}], hoverChange: [{
|
|
206
204
|
type: Output
|
|
207
205
|
}] } });
|
|
208
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-common.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Action, ApiResponse, Field } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-select-common',\r\n  templateUrl: './select-common.component.html',\r\n  styleUrls: ['./select-common.component.css']\r\n})\r\nexport class SelectCommonComponent implements OnInit, OnDestroy {\r\n\r\n  constructor(protected messageService: MessageService, protected dataService: DataServiceLib,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.placeholder == \"\") {\r\n      this.placeholder = \"Select \" + this.display;\r\n    }\r\n\r\n    this.setDefaultValue();\r\n\r\n    if (this.field?.optionsSubject) {\r\n      this.subscription = this.field.optionsSubject.subscribe(newOptions => {\r\n        if (newOptions) {\r\n          this.options = newOptions;\r\n          this.updateSelectedOptionHint(); // Changed: Update hint when options change\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (this.readonlyMode != \"\" && this.options.length > 0) {\r\n      this.displayValue = this.options.filter((m) => m[`${this.optionValue}`] == this.value)[0][`${this.optionDisplay}`]\r\n    }\r\n\r\n    //add a null option\r\n    if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {\r\n      this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: \"None\" })\r\n    }\r\n\r\n    this.updateSelectedOptionHint(); // Changed: Update hint when component inputs change\r\n  }\r\n\r\n  displayValue;\r\n  isHovered = false;\r\n  selectedOptionHint = \"\"; // Changed: Added property to store the hint for selected option\r\n\r\n  private subscription: Subscription;\r\n\r\n  @Input() width = \"100%\"\r\n  @Input() readonly = false;\r\n  @Input() required = true;\r\n  @Input() defaultFirstValue = false;\r\n  @Input() readonlyMode = \"\";\r\n  @Input() hint = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() multiple: boolean = false;\r\n\r\n  @Input() display = \"\";\r\n  @Input() value;\r\n  @Input() options: any;\r\n  @Input() masterOptions: any;\r\n  @Input() masterField: string;\r\n  @Input() optionValue = \"\";\r\n  @Input() optionDisplay = \"\";\r\n  @Input() optionDisplayExtra = \"\";\r\n  @Input() nullable = false;\r\n\r\n  @Input() infoMessage: string;\r\n  @Input() copyContent = false;\r\n  @Input() loadAction: Action;\r\n  @Input() loadIDField: string;\r\n  @Input() field: Field;\r\n  @Input() data: any;\r\n\r\n  @Output() valueChange = new EventEmitter();\r\n  @Output() hoverChange = new EventEmitter<boolean>();\r\n\r\n  setDefaultValue(){\r\n    if (\r\n      this.defaultFirstValue && this.options && this.options.length > 0 &&\r\n      (this.value == null || this.value == undefined || (typeof (this.value) == 'string' && this.value == '') || (typeof (this.value) == 'number' && this.value == 0))\r\n      ) {\r\n\r\n      this.value = this.options[0][this.optionValue]\r\n      this.changed();\r\n    }\r\n  }\r\n\r\n  changed() {\r\n    this.valueChange.emit(this.value);\r\n    this.updateSelectedOptionHint(); // Changed: Update hint when value changes\r\n  }\r\n\r\n  // Changed: Added method to update hint based on selected option\r\n  private updateSelectedOptionHint(): void {\r\n    if (!this.options || this.options.length === 0 || this.value == null || this.value == undefined) {\r\n      this.selectedOptionHint = this.hint; // Fall back to component hint\r\n      return;\r\n    }\r\n\r\n    const selectedOption = this.options.find(option => \r\n      option[this.optionValue] === this.value\r\n    );\r\n\r\n    if (selectedOption && selectedOption.hint) {\r\n      this.selectedOptionHint = selectedOption.hint; // Use option hint\r\n    } else {\r\n      this.selectedOptionHint = this.hint; // Fall back to component hint\r\n    }\r\n  }\r\n\r\n  // Changed: Added getter for computed hint to use in template\r\n  get computedHint(): string {\r\n    return this.selectedOptionHint || this.hint;\r\n  }\r\n\r\n  onMouseEnter(): void {\r\n    this.isHovered = true;\r\n    this.hoverChange.emit(true);\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    this.isHovered = false;\r\n    this.hoverChange.emit(false);\r\n  }\r\n\r\n  refresh(event: MouseEvent): void {\r\n    console.log(\"refresh clicked\")\r\n    event.stopPropagation();\r\n    if (!this.loadAction) {\r\n      return;\r\n    }\r\n\r\n    const refreshAction : Action = {\r\n      ...this.loadAction,\r\n      skipCache: true\r\n    };\r\n\r\n    this.getData(refreshAction);\r\n  }\r\n\r\n  private transformLoadUrl(action: Action): Action {\r\n    if (!action?.url || !this.loadIDField || !this.data) return action;\r\n\r\n    const idValue = this.data[this.loadIDField];\r\n    if (!idValue) return action;\r\n\r\n    const urlParts = action.url.split('/');\r\n    return {\r\n      ...action,\r\n      url: `${urlParts[0]}/${urlParts[1]}/${idValue}`\r\n    };\r\n  }\r\n\r\n  getData(loadAction: Action) {\r\n\r\n    if (!loadAction) return;\r\n    if (this.masterField) return;\r\n\r\n    const transformedAction = this.transformLoadUrl(loadAction);\r\n\r\n    this.dataService.CallApi(transformedAction, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n        this.options = apiResponse.data;\r\n\r\n        console.log(this.options)\r\n\r\n        if (this.field) {\r\n          this.field.options = apiResponse.data;\r\n\r\n          this.setDefaultValue();\r\n\r\n          if (!this.field.optionsSubject) {\r\n            this.field.optionsSubject = new BehaviorSubject(apiResponse.data);\r\n          } else {\r\n            this.field.optionsSubject.next(apiResponse.data);\r\n          }\r\n        }\r\n        \r\n        this.updateSelectedOptionHint(); // Changed: Update hint when data is loaded\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n}","<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"computedHint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n  <mat-label>{{display}}</mat-label>\r\n  <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n    <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n      {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <div matSuffix class=\"suffix-icons\">\r\n    <ng-content select=\"[additionalButtons]\"></ng-content>\r\n    <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">cached</mat-icon>\r\n    </button>\r\n    <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n  </div>\r\n\r\n</mat-form-field>\r\n"]}
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-common.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Action, ApiResponse, Field } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-select-common',\r\n  templateUrl: './select-common.component.html',\r\n  styleUrls: ['./select-common.component.css']\r\n})\r\nexport class SelectCommonComponent implements OnInit, OnDestroy {\r\n\r\n  constructor(protected messageService: MessageService, protected dataService: DataServiceLib,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.placeholder == \"\") {\r\n      this.placeholder = \"Select \" + this.display;\r\n    }\r\n\r\n    this.setDefaultValue();\r\n\r\n    if (this.field?.optionsSubject) {\r\n      this.subscription = this.field.optionsSubject.subscribe(newOptions => {\r\n        if (newOptions) {\r\n          this.options = newOptions;\r\n          this.updateSelectedOptionHint();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (this.readonlyMode != \"\" && this.options.length > 0) {\r\n      this.displayValue = this.options.filter((m) => m[`${this.optionValue}`] == this.value)[0][`${this.optionDisplay}`]\r\n    }\r\n\r\n    //add a null option\r\n    if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {\r\n      this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: \"None\" })\r\n    }\r\n\r\n    this.updateSelectedOptionHint();\r\n  }\r\n\r\n  displayValue;\r\n  isHovered = false;\r\n  selectedOptionHint = \"\";\r\n\r\n  private subscription: Subscription;\r\n\r\n  @Input() width = \"100%\"\r\n  @Input() readonly = false;\r\n  @Input() required = true;\r\n  @Input() defaultFirstValue = false;\r\n  @Input() readonlyMode = \"\";\r\n  @Input() hint = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() multiple: boolean = false;\r\n\r\n  @Input() display = \"\";\r\n  @Input() value;\r\n  @Input() options: any;\r\n  @Input() masterOptions: any;\r\n  @Input() masterField: string;\r\n  @Input() optionValue = \"\";\r\n  @Input() optionDisplay = \"\";\r\n  @Input() optionDisplayExtra = \"\";\r\n  @Input() nullable = false;\r\n\r\n  @Input() infoMessage: string;\r\n  @Input() copyContent = false;\r\n  @Input() loadAction: Action;\r\n  @Input() loadIDField: string;\r\n  @Input() field: Field;\r\n  @Input() data: any;\r\n\r\n  @Output() valueChange = new EventEmitter();\r\n  @Output() hoverChange = new EventEmitter<boolean>();\r\n\r\n  setDefaultValue(){\r\n    if (\r\n      this.defaultFirstValue && this.options && this.options.length > 0 &&\r\n      (this.value == null || this.value == undefined || (typeof (this.value) == 'string' && this.value == '') || (typeof (this.value) == 'number' && this.value == 0))\r\n      ) {\r\n\r\n      this.value = this.options[0][this.optionValue]\r\n      this.changed();\r\n    }\r\n  }\r\n\r\n  changed() {\r\n    this.valueChange.emit(this.value);\r\n    this.updateSelectedOptionHint();\r\n  }\r\n\r\n  private updateSelectedOptionHint(): void {\r\n    if (!this.options || this.options.length === 0 || this.value == null || this.value == undefined) {\r\n      this.selectedOptionHint = this.hint; // Fall back to component hint\r\n      return;\r\n    }\r\n\r\n    const selectedOption = this.options.find(option => \r\n      option[this.optionValue] === this.value\r\n    );\r\n\r\n    if (selectedOption && selectedOption.hint) {\r\n      this.selectedOptionHint = selectedOption.hint; // Use option hint\r\n    } else {\r\n      this.selectedOptionHint = this.hint; // Fall back to component hint\r\n    }\r\n  }\r\n\r\n  get computedHint(): string {\r\n    return this.selectedOptionHint || this.hint;\r\n  }\r\n\r\n  onMouseEnter(): void {\r\n    this.isHovered = true;\r\n    this.hoverChange.emit(true);\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    this.isHovered = false;\r\n    this.hoverChange.emit(false);\r\n  }\r\n\r\n  refresh(event: MouseEvent): void {\r\n    console.log(\"refresh clicked\")\r\n    event.stopPropagation();\r\n    if (!this.loadAction) {\r\n      return;\r\n    }\r\n\r\n    const refreshAction : Action = {\r\n      ...this.loadAction,\r\n      skipCache: true\r\n    };\r\n\r\n    this.getData(refreshAction);\r\n  }\r\n\r\n  private transformLoadUrl(action: Action): Action {\r\n    if (!action?.url || !this.loadIDField || !this.data) return action;\r\n\r\n    const idValue = this.data[this.loadIDField];\r\n    if (!idValue) return action;\r\n\r\n    const urlParts = action.url.split('/');\r\n    return {\r\n      ...action,\r\n      url: `${urlParts[0]}/${urlParts[1]}/${idValue}`\r\n    };\r\n  }\r\n\r\n  getData(loadAction: Action) {\r\n\r\n    if (!loadAction) return;\r\n    if (this.masterField) return;\r\n\r\n    const transformedAction = this.transformLoadUrl(loadAction);\r\n\r\n    this.dataService.CallApi(transformedAction, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n        this.options = apiResponse.data;\r\n\r\n        console.log(this.options)\r\n\r\n        if (this.field) {\r\n          this.field.options = apiResponse.data;\r\n\r\n          this.setDefaultValue();\r\n\r\n          if (!this.field.optionsSubject) {\r\n            this.field.optionsSubject = new BehaviorSubject(apiResponse.data);\r\n          } else {\r\n            this.field.optionsSubject.next(apiResponse.data);\r\n          }\r\n        }\r\n        \r\n        this.updateSelectedOptionHint();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n}","<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"computedHint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"false\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n  <mat-label>{{display}}</mat-label>\r\n  <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\" [required]=\"required\">\r\n    <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n      {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <div matSuffix class=\"suffix-icons\">\r\n    <ng-content select=\"[additionalButtons]\"></ng-content>\r\n    <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">cached</mat-icon>\r\n    </button>\r\n    <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n  </div>\r\n\r\n</mat-form-field>\r\n"]}
|
|
@@ -20,7 +20,6 @@ export class StatusesComponent {
|
|
|
20
20
|
getIcon(item) {
|
|
21
21
|
if (!this.data || !item.states)
|
|
22
22
|
return '';
|
|
23
|
-
// Changed: pass entire data object to condition function
|
|
24
23
|
const matchingState = item.states.find(state => state.condition(this.data));
|
|
25
24
|
return matchingState ? matchingState.icon : '';
|
|
26
25
|
}
|
|
@@ -28,7 +27,6 @@ export class StatusesComponent {
|
|
|
28
27
|
getIconColor(item) {
|
|
29
28
|
if (!this.data || !item.states)
|
|
30
29
|
return '';
|
|
31
|
-
// Changed: pass entire data object to condition function
|
|
32
30
|
const matchingState = item.states.find(state => state.condition(this.data));
|
|
33
31
|
return matchingState ? matchingState.color : '';
|
|
34
32
|
}
|
|
@@ -43,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
43
41
|
}], data: [{
|
|
44
42
|
type: Input
|
|
45
43
|
}] } });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzZXMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc3RhdHVzZXMvc3RhdHVzZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc3RhdHVzZXMvc3RhdHVzZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBVWpELE1BQU0sT0FBTyxpQkFBaUI7SUFLNUIsa0RBQWtEO0lBQ2xELGtCQUFrQjtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDN0MsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUN0RixDQUFDO0lBRUQsb0RBQW9EO0lBQ3BELGFBQWEsQ0FBQyxJQUFnQjtRQUM1QixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUk7WUFBRSxPQUFPLEtBQUssQ0FBQztRQUM3QixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUN4RSxDQUFDO0lBRUQsMERBQTBEO0lBQzFELE9BQU8sQ0FBQyxJQUFnQjtRQUN0QixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNO1lBQUUsT0FBTyxFQUFFLENBQUM7UUFFMUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBRTVFLE9BQU8sYUFBYSxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDakQsQ0FBQztJQUVELGdFQUFnRTtJQUNoRSxZQUFZLENBQUMsSUFBZ0I7UUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTTtZQUFFLE9BQU8sRUFBRSxDQUFDO1FBRTFDLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUU1RSxPQUFPLGFBQWEsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ2xELENBQUM7OzhHQWpDVSxpQkFBaUI7a0dBQWpCLGlCQUFpQixnR0NWOUIscVpBVU07MkZEQU8saUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLGNBQWM7OEJBTWYsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3RhdHVzQ29uZmlnLCBTdGF0dXNJdGVtIH0gZnJvbSAnLi4vLi4vY2xhc3Nlcy9DbGFzc2VzJztcclxuXHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtc3RhdHVzZXMnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9zdGF0dXNlcy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vc3RhdHVzZXMuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTdGF0dXNlc0NvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIGNvbmZpZzogU3RhdHVzQ29uZmlnO1xyXG4gIEBJbnB1dCgpIGRhdGE6IGFueTtcclxuXHJcbiAgLy8gQ2hlY2sgaWYgdGhlIGVudGlyZSBjb21wb25lbnQgc2hvdWxkIGJlIHZpc2libGVcclxuICBpc0NvbXBvbmVudFZpc2libGUoKTogYm9vbGVhbiB7XHJcbiAgICBpZiAoIXRoaXMuY29uZmlnIHx8ICF0aGlzLmRhdGEpIHJldHVybiBmYWxzZTtcclxuICAgIHJldHVybiB0aGlzLmNvbmZpZy5oaWRkZW5Db25kaXRpb24gPyAhdGhpcy5jb25maWcuaGlkZGVuQ29uZGl0aW9uKHRoaXMuZGF0YSkgOiB0cnVlO1xyXG4gIH1cclxuXHJcbiAgLy8gQ2hlY2sgaWYgaW5kaXZpZHVhbCBzdGF0dXMgaXRlbSBzaG91bGQgYmUgdmlzaWJsZVxyXG4gIGlzSXRlbVZpc2libGUoaXRlbTogU3RhdHVzSXRlbSk6IGJvb2xlYW4ge1xyXG4gICAgaWYgKCF0aGlzLmRhdGEpIHJldHVybiBmYWxzZTtcclxuICAgIHJldHVybiBpdGVtLmhpZGRlbkNvbmRpdGlvbiA/ICFpdGVtLmhpZGRlbkNvbmRpdGlvbih0aGlzLmRhdGEpIDogdHJ1ZTtcclxuICB9XHJcblxyXG4gIC8vIEdldCB0aGUgaWNvbiBiYXNlZCBvbiBzdGF0dXMgdmFsdWUgYW5kIHN0YXRlIGNvbmRpdGlvbnNcclxuICBnZXRJY29uKGl0ZW06IFN0YXR1c0l0ZW0pOiBzdHJpbmcge1xyXG4gICAgaWYgKCF0aGlzLmRhdGEgfHwgIWl0ZW0uc3RhdGVzKSByZXR1cm4gJyc7XHJcbiAgICBcclxuICAgIGNvbnN0IG1hdGNoaW5nU3RhdGUgPSBpdGVtLnN0YXRlcy5maW5kKHN0YXRlID0+IHN0YXRlLmNvbmRpdGlvbih0aGlzLmRhdGEpKTtcclxuICAgIFxyXG4gICAgcmV0dXJuIG1hdGNoaW5nU3RhdGUgPyBtYXRjaGluZ1N0YXRlLmljb24gOiAnJztcclxuICB9XHJcblxyXG4gIC8vIEdldCB0aGUgaWNvbiBjb2xvciBiYXNlZCBvbiBzdGF0dXMgdmFsdWUgYW5kIHN0YXRlIGNvbmRpdGlvbnNcclxuICBnZXRJY29uQ29sb3IoaXRlbTogU3RhdHVzSXRlbSk6IHN0cmluZyB7XHJcbiAgICBpZiAoIXRoaXMuZGF0YSB8fCAhaXRlbS5zdGF0ZXMpIHJldHVybiAnJztcclxuICAgIFxyXG4gICAgY29uc3QgbWF0Y2hpbmdTdGF0ZSA9IGl0ZW0uc3RhdGVzLmZpbmQoc3RhdGUgPT4gc3RhdGUuY29uZGl0aW9uKHRoaXMuZGF0YSkpO1xyXG4gICAgXHJcbiAgICByZXR1cm4gbWF0Y2hpbmdTdGF0ZSA/IG1hdGNoaW5nU3RhdGUuY29sb3IgOiAnJztcclxuICB9XHJcbn0iLCI8ZGl2ICpuZ0lmPVwiaXNDb21wb25lbnRWaXNpYmxlKClcIiBjbGFzcz1cInN0YXR1c2VzLWNvbnRhaW5lclwiPlxyXG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgY29uZmlnLml0ZW1zXCI+XHJcbiAgICA8YnV0dG9uIFxyXG4gICAgICAqbmdJZj1cImlzSXRlbVZpc2libGUoaXRlbSlcIlxyXG4gICAgICBtYXQtc3Ryb2tlZC1idXR0b24gXHJcbiAgICAgIGNsYXNzPVwic3RhdHVzLWJ1dHRvblwiPlxyXG4gICAgICB7e2l0ZW0ubmFtZX19IFxyXG4gICAgICA8bWF0LWljb24gW25nU3R5bGVdPVwieydjb2xvcic6IGdldEljb25Db2xvcihpdGVtKX1cIj57e2dldEljb24oaXRlbSl9fTwvbWF0LWljb24+XHJcbiAgICA8L2J1dHRvbj5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9kaXY+Il19
|