@dereekb/dbx-form 9.24.15 → 9.24.17

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.
@@ -36,7 +36,40 @@ export function numberField(config) {
36
36
  parsers
37
37
  });
38
38
  }
39
+ export function numberSliderField(config) {
40
+ const { key, min, max, step, enforceStep, inputType: type = 'number', materialFormField, thumbLabel: inputThumbLabel, tickInterval: inputTickInterval, invertSelectionColoring: invertedSelectionColoring = false, displayWith } = config;
41
+ const parsers = numberFieldTransformParser(config);
42
+ const validators = [];
43
+ let tickIntervalFromSteps;
44
+ if (step) {
45
+ tickIntervalFromSteps = 1;
46
+ if (enforceStep) {
47
+ validators.push(isDivisibleBy(step));
48
+ }
49
+ }
50
+ const tickInterval = inputTickInterval === false ? undefined : inputTickInterval ?? tickIntervalFromSteps ?? undefined;
51
+ return formlyField({
52
+ key,
53
+ type: 'slider',
54
+ ...propsAndConfigForFieldConfig(config, {
55
+ ...materialFormField,
56
+ type,
57
+ min,
58
+ max,
59
+ step,
60
+ inverted: invertedSelectionColoring,
61
+ thumbLabel: inputThumbLabel ?? true,
62
+ showTickMarks: Boolean(tickInterval),
63
+ tickInterval,
64
+ displayWith
65
+ }),
66
+ ...validatorsForFieldConfig({
67
+ validators
68
+ }),
69
+ parsers
70
+ });
71
+ }
39
72
  export function dollarAmountField(config) {
40
73
  return numberField({ ...config, transform: { ...config.transform, precision: 2 } });
41
74
  }
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvdmFsdWUvbnVtYmVyL251bWJlci5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsWUFBWSxFQUFvQyx1QkFBdUIsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxSCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUE2QyxXQUFXLEVBQUUsNEJBQTRCLEVBQTBCLHdCQUF3QixFQUFxRSxNQUFNLGFBQWEsQ0FBQztBQWV4TyxNQUFNLFVBQVUsMEJBQTBCLENBQUMsTUFBa0Y7SUFDM0gsTUFBTSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQ3BELElBQUksT0FBd0MsQ0FBQztJQUU3QyxJQUFJLFlBQVksRUFBRTtRQUNoQixPQUFPLEdBQUcsWUFBWSxDQUFDO0tBQ3hCO0lBRUQsSUFBSSxTQUFTLEVBQUU7UUFDYixNQUFNLGVBQWUsR0FBc0IsZ0JBQWdCLENBQUMsdUJBQXVCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztRQUNoRyxPQUFPLEdBQUcsWUFBWSxDQUFDLENBQUMsZUFBZSxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUM7S0FDcEQ7SUFFRCxPQUFPLE9BQU8sQ0FBQztBQUNqQixDQUFDO0FBRUQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxNQUF5QjtJQUNuRCxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsSUFBSSxHQUFHLFFBQVEsRUFBRSxpQkFBaUIsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUNuRyxNQUFNLE9BQU8sR0FBRywwQkFBMEIsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUVuRCxNQUFNLFVBQVUsR0FBa0IsRUFBRSxDQUFDO0lBRXJDLElBQUksSUFBSSxJQUFJLFdBQVcsRUFBRTtRQUN2QixVQUFVLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0tBQ3RDO0lBRUQsT0FBTyxXQUFXLENBQUM7UUFDakIsR0FBRztRQUNILElBQUksRUFBRSxPQUFPO1FBQ2IsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7WUFDdEMsR0FBRyxpQkFBaUI7WUFDcEIsSUFBSTtZQUNKLEdBQUc7WUFDSCxHQUFHO1lBQ0gsSUFBSTtTQUNMLENBQUM7UUFDRixHQUFHLHdCQUF3QixDQUFDO1lBQzFCLFVBQVU7U0FDWCxDQUFDO1FBQ0YsT0FBTztLQUNSLENBQUMsQ0FBQztBQUNMLENBQUM7QUFJRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsTUFBK0I7SUFDL0QsT0FBTyxXQUFXLENBQUMsRUFBRSxHQUFHLE1BQU0sRUFBRSxTQUFTLEVBQUUsRUFBRSxHQUFHLE1BQU0sQ0FBQyxTQUFTLEVBQUUsU0FBUyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztBQUN0RixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmFsaWRhdG9yRm4gfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBjb25jYXRBcnJheXMsIFRyYW5zZm9ybU51bWJlckZ1bmN0aW9uQ29uZmlnUmVmLCB0cmFuc2Zvcm1OdW1iZXJGdW5jdGlvbiwgbWFwTWF5YmVGdW5jdGlvbiB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IGlzRGl2aXNpYmxlQnkgfSBmcm9tICcuLi8uLi8uLi8uLi92YWxpZGF0b3InO1xuaW1wb3J0IHsgQXR0cmlidXRlc0ZpZWxkQ29uZmlnLCBMYWJlbGVkRmllbGRDb25maWcsIGZvcm1seUZpZWxkLCBwcm9wc0FuZENvbmZpZ0ZvckZpZWxkQ29uZmlnLCBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCB2YWxpZGF0b3JzRm9yRmllbGRDb25maWcsIEZpZWxkQ29uZmlnUGFyc2Vyc1JlZiwgRm9ybWx5VmFsdWVQYXJzZXIsIE1hdGVyaWFsRm9ybUZpZWxkQ29uZmlnIH0gZnJvbSAnLi4vLi4vZmllbGQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE51bWJlckZpZWxkTnVtYmVyQ29uZmlnIHtcbiAgbWluPzogbnVtYmVyO1xuICBtYXg/OiBudW1iZXI7XG4gIHN0ZXA/OiBudW1iZXI7XG4gIGVuZm9yY2VTdGVwPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgTnVtYmVyRmllbGRJbnB1dFR5cGUgPSAnbnVtYmVyJztcblxuZXhwb3J0IGludGVyZmFjZSBOdW1iZXJGaWVsZENvbmZpZyBleHRlbmRzIExhYmVsZWRGaWVsZENvbmZpZywgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgTnVtYmVyRmllbGROdW1iZXJDb25maWcsIEF0dHJpYnV0ZXNGaWVsZENvbmZpZywgUGFydGlhbDxUcmFuc2Zvcm1OdW1iZXJGdW5jdGlvbkNvbmZpZ1JlZj4sIE1hdGVyaWFsRm9ybUZpZWxkQ29uZmlnIHtcbiAgaW5wdXRUeXBlPzogTnVtYmVyRmllbGRJbnB1dFR5cGU7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBudW1iZXJGaWVsZFRyYW5zZm9ybVBhcnNlcihjb25maWc6IFBhcnRpYWw8RmllbGRDb25maWdQYXJzZXJzUmVmPiAmIFBhcnRpYWw8VHJhbnNmb3JtTnVtYmVyRnVuY3Rpb25Db25maWdSZWY+KSB7XG4gIGNvbnN0IHsgcGFyc2VyczogaW5wdXRQYXJzZXJzLCB0cmFuc2Zvcm0gfSA9IGNvbmZpZztcbiAgbGV0IHBhcnNlcnM6IEZvcm1seVZhbHVlUGFyc2VyW10gfCB1bmRlZmluZWQ7XG5cbiAgaWYgKGlucHV0UGFyc2Vycykge1xuICAgIHBhcnNlcnMgPSBpbnB1dFBhcnNlcnM7XG4gIH1cblxuICBpZiAodHJhbnNmb3JtKSB7XG4gICAgY29uc3QgdHJhbnNmb3JtUGFyc2VyOiBGb3JtbHlWYWx1ZVBhcnNlciA9IG1hcE1heWJlRnVuY3Rpb24odHJhbnNmb3JtTnVtYmVyRnVuY3Rpb24odHJhbnNmb3JtKSk7XG4gICAgcGFyc2VycyA9IGNvbmNhdEFycmF5cyhbdHJhbnNmb3JtUGFyc2VyXSwgcGFyc2Vycyk7XG4gIH1cblxuICByZXR1cm4gcGFyc2Vycztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG51bWJlckZpZWxkKGNvbmZpZzogTnVtYmVyRmllbGRDb25maWcpOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5LCBtaW4sIG1heCwgc3RlcCwgZW5mb3JjZVN0ZXAsIGlucHV0VHlwZTogdHlwZSA9ICdudW1iZXInLCBtYXRlcmlhbEZvcm1GaWVsZCB9ID0gY29uZmlnO1xuICBjb25zdCBwYXJzZXJzID0gbnVtYmVyRmllbGRUcmFuc2Zvcm1QYXJzZXIoY29uZmlnKTtcblxuICBjb25zdCB2YWxpZGF0b3JzOiBWYWxpZGF0b3JGbltdID0gW107XG5cbiAgaWYgKHN0ZXAgJiYgZW5mb3JjZVN0ZXApIHtcbiAgICB2YWxpZGF0b3JzLnB1c2goaXNEaXZpc2libGVCeShzdGVwKSk7XG4gIH1cblxuICByZXR1cm4gZm9ybWx5RmllbGQoe1xuICAgIGtleSxcbiAgICB0eXBlOiAnaW5wdXQnLFxuICAgIC4uLnByb3BzQW5kQ29uZmlnRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICAuLi5tYXRlcmlhbEZvcm1GaWVsZCxcbiAgICAgIHR5cGUsXG4gICAgICBtaW4sXG4gICAgICBtYXgsXG4gICAgICBzdGVwXG4gICAgfSksXG4gICAgLi4udmFsaWRhdG9yc0ZvckZpZWxkQ29uZmlnKHtcbiAgICAgIHZhbGlkYXRvcnNcbiAgICB9KSxcbiAgICBwYXJzZXJzXG4gIH0pO1xufVxuXG5leHBvcnQgdHlwZSBEb2xsYXJBbW91bnRGaWVsZENvbmZpZyA9IE9taXQ8TnVtYmVyRmllbGRDb25maWcsICdyb3VuZFRvU3RlcCcgfCAncHJlY2lzaW9uJz47XG5cbmV4cG9ydCBmdW5jdGlvbiBkb2xsYXJBbW91bnRGaWVsZChjb25maWc6IERvbGxhckFtb3VudEZpZWxkQ29uZmlnKSB7XG4gIHJldHVybiBudW1iZXJGaWVsZCh7IC4uLmNvbmZpZywgdHJhbnNmb3JtOiB7IC4uLmNvbmZpZy50cmFuc2Zvcm0sIHByZWNpc2lvbjogMiB9IH0pO1xufVxuIl19
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number.field.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/number/number.field.ts"],"names":[],"mappings":"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","sourcesContent":["import { ValidatorFn } from '@angular/forms';\nimport { concatArrays, TransformNumberFunctionConfigRef, transformNumberFunction, mapMaybeFunction } from '@dereekb/util';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\nimport { isDivisibleBy } from '../../../../validator';\nimport { AttributesFieldConfig, LabeledFieldConfig, formlyField, propsAndConfigForFieldConfig, DescriptionFieldConfig, validatorsForFieldConfig, FieldConfigParsersRef, FormlyValueParser, MaterialFormFieldConfig } from '../../field';\n\nexport interface NumberFieldNumberConfig {\n  min?: number;\n  max?: number;\n  step?: number;\n  enforceStep?: boolean;\n}\n\nexport type NumberFieldInputType = 'number';\n\nexport interface NumberFieldConfig extends LabeledFieldConfig, DescriptionFieldConfig, NumberFieldNumberConfig, AttributesFieldConfig, Partial<TransformNumberFunctionConfigRef>, MaterialFormFieldConfig {\n  inputType?: NumberFieldInputType;\n}\n\nexport function numberFieldTransformParser(config: Partial<FieldConfigParsersRef> & Partial<TransformNumberFunctionConfigRef>) {\n  const { parsers: inputParsers, transform } = config;\n  let parsers: FormlyValueParser[] | undefined;\n\n  if (inputParsers) {\n    parsers = inputParsers;\n  }\n\n  if (transform) {\n    const transformParser: FormlyValueParser = mapMaybeFunction(transformNumberFunction(transform));\n    parsers = concatArrays([transformParser], parsers);\n  }\n\n  return parsers;\n}\n\nexport function numberField(config: NumberFieldConfig): FormlyFieldConfig {\n  const { key, min, max, step, enforceStep, inputType: type = 'number', materialFormField } = config;\n  const parsers = numberFieldTransformParser(config);\n\n  const validators: ValidatorFn[] = [];\n\n  if (step && enforceStep) {\n    validators.push(isDivisibleBy(step));\n  }\n\n  return formlyField({\n    key,\n    type: 'input',\n    ...propsAndConfigForFieldConfig(config, {\n      ...materialFormField,\n      type,\n      min,\n      max,\n      step\n    }),\n    ...validatorsForFieldConfig({\n      validators\n    }),\n    parsers\n  });\n}\n\nexport interface NumberSliderFieldConfig extends NumberFieldConfig {\n  /**\n   * Max value. Required for the slider.\n   */\n  max: number;\n  /**\n   * Whether or not to show the thumb label while sliding. Defaults to true.\n   */\n  thumbLabel?: boolean;\n  /**\n   * Whether or not to invert the selection line.\n   */\n  invertSelectionColoring?: boolean;\n  /**\n   * Tick interval. If not provided defaults to the step value, if provided. If false, the ticks are disabled.\n   *\n   * The tick interval is the number of \"steps\" to show between ticks.\n   *\n   * For example, a tick interval of 5 show a tick every 5 steps. If steps are 10, it will show a tick at every number divisible by 50 (5 * 10).\n   */\n  tickInterval?: false | number;\n  /**\n   * Custom display with function for the thumbLabel.\n   */\n  displayWith?: (value: number) => string;\n}\n\nexport function numberSliderField(config: NumberSliderFieldConfig): FormlyFieldConfig {\n  const { key, min, max, step, enforceStep, inputType: type = 'number', materialFormField, thumbLabel: inputThumbLabel, tickInterval: inputTickInterval, invertSelectionColoring: invertedSelectionColoring = false, displayWith } = config;\n  const parsers = numberFieldTransformParser(config);\n\n  const validators: ValidatorFn[] = [];\n  let tickIntervalFromSteps: number | undefined;\n\n  if (step) {\n    tickIntervalFromSteps = 1;\n\n    if (enforceStep) {\n      validators.push(isDivisibleBy(step));\n    }\n  }\n\n  const tickInterval: number | undefined = inputTickInterval === false ? undefined : inputTickInterval ?? tickIntervalFromSteps ?? undefined;\n\n  return formlyField({\n    key,\n    type: 'slider',\n    ...propsAndConfigForFieldConfig(config, {\n      ...materialFormField,\n      type,\n      min,\n      max,\n      step,\n      inverted: invertedSelectionColoring,\n      thumbLabel: inputThumbLabel ?? true,\n      showTickMarks: Boolean(tickInterval),\n      tickInterval,\n      displayWith\n    }),\n    ...validatorsForFieldConfig({\n      validators\n    }),\n    parsers\n  });\n}\n\nexport type DollarAmountFieldConfig = Omit<NumberFieldConfig, 'roundToStep' | 'precision'>;\n\nexport function dollarAmountField(config: DollarAmountFieldConfig) {\n  return numberField({ ...config, transform: { ...config.transform, precision: 2 } });\n}\n"]}
@@ -1,18 +1,19 @@
1
1
  import { FormlyMaterialModule } from '@ngx-formly/material';
2
+ import { FormlyMatSliderModule } from '@ngx-formly/material/slider';
2
3
  import { NgModule } from '@angular/core';
3
4
  import { DbxFormFormlyWrapperModule } from '../../wrapper/form.wrapper.module';
4
5
  import * as i0 from "@angular/core";
5
6
  export class DbxFormFormlyNumberFieldModule {
6
7
  }
7
8
  DbxFormFormlyNumberFieldModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormFormlyNumberFieldModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
- DbxFormFormlyNumberFieldModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxFormFormlyNumberFieldModule, imports: [FormlyMaterialModule], exports: [DbxFormFormlyWrapperModule] });
9
- DbxFormFormlyNumberFieldModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormFormlyNumberFieldModule, imports: [FormlyMaterialModule, DbxFormFormlyWrapperModule] });
9
+ DbxFormFormlyNumberFieldModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxFormFormlyNumberFieldModule, imports: [FormlyMaterialModule, FormlyMatSliderModule], exports: [DbxFormFormlyWrapperModule] });
10
+ DbxFormFormlyNumberFieldModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormFormlyNumberFieldModule, imports: [FormlyMaterialModule, FormlyMatSliderModule, DbxFormFormlyWrapperModule] });
10
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormFormlyNumberFieldModule, decorators: [{
11
12
  type: NgModule,
12
13
  args: [{
13
- imports: [FormlyMaterialModule],
14
+ imports: [FormlyMaterialModule, FormlyMatSliderModule],
14
15
  declarations: [],
15
16
  exports: [DbxFormFormlyWrapperModule]
16
17
  }]
17
18
  }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmZpZWxkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybWx5L2ZpZWxkL3ZhbHVlL251bWJlci9udW1iZXIuZmllbGQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzVELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBTy9FLE1BQU0sT0FBTyw4QkFBOEI7OzRIQUE5Qiw4QkFBOEI7NkhBQTlCLDhCQUE4QixZQUovQixvQkFBb0IsYUFFcEIsMEJBQTBCOzZIQUV6Qiw4QkFBOEIsWUFKL0Isb0JBQW9CLEVBRXBCLDBCQUEwQjs0RkFFekIsOEJBQThCO2tCQUwxQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDO29CQUMvQixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsMEJBQTBCLENBQUM7aUJBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybWx5TWF0ZXJpYWxNb2R1bGUgfSBmcm9tICdAbmd4LWZvcm1seS9tYXRlcmlhbCc7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybUZvcm1seVdyYXBwZXJNb2R1bGUgfSBmcm9tICcuLi8uLi93cmFwcGVyL2Zvcm0ud3JhcHBlci5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbRm9ybWx5TWF0ZXJpYWxNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBleHBvcnRzOiBbRGJ4Rm9ybUZvcm1seVdyYXBwZXJNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1Gb3JtbHlOdW1iZXJGaWVsZE1vZHVsZSB7fVxuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmZpZWxkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybWx5L2ZpZWxkL3ZhbHVlL251bWJlci9udW1iZXIuZmllbGQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzVELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBTy9FLE1BQU0sT0FBTyw4QkFBOEI7OzRIQUE5Qiw4QkFBOEI7NkhBQTlCLDhCQUE4QixZQUovQixvQkFBb0IsRUFBRSxxQkFBcUIsYUFFM0MsMEJBQTBCOzZIQUV6Qiw4QkFBOEIsWUFKL0Isb0JBQW9CLEVBQUUscUJBQXFCLEVBRTNDLDBCQUEwQjs0RkFFekIsOEJBQThCO2tCQUwxQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixFQUFFLHFCQUFxQixDQUFDO29CQUN0RCxZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsMEJBQTBCLENBQUM7aUJBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybWx5TWF0ZXJpYWxNb2R1bGUgfSBmcm9tICdAbmd4LWZvcm1seS9tYXRlcmlhbCc7XG5pbXBvcnQgeyBGb3JtbHlNYXRTbGlkZXJNb2R1bGUgfSBmcm9tICdAbmd4LWZvcm1seS9tYXRlcmlhbC9zbGlkZXInO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEZvcm1Gb3JtbHlXcmFwcGVyTW9kdWxlIH0gZnJvbSAnLi4vLi4vd3JhcHBlci9mb3JtLndyYXBwZXIubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0Zvcm1seU1hdGVyaWFsTW9kdWxlLCBGb3JtbHlNYXRTbGlkZXJNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBleHBvcnRzOiBbRGJ4Rm9ybUZvcm1seVdyYXBwZXJNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1Gb3JtbHlOdW1iZXJGaWVsZE1vZHVsZSB7fVxuIl19
@@ -3,10 +3,10 @@ import { formlyField, propsAndConfigForFieldConfig, flexLayoutWrapper, toggleFie
3
3
  import * as i0 from '@angular/core';
4
4
  import { Injectable, SkipSelf, Directive, Injector, Optional, Component, Inject, Input, ElementRef, ViewChild, ChangeDetectionStrategy, EventEmitter, Output, InjectionToken, NgModule } from '@angular/core';
5
5
  import { FieldType } from '@ngx-formly/material';
6
- import { switchMap, first, tap, map, distinctUntilChanged, shareReplay, combineLatestWith, BehaviorSubject, of, startWith, filter, throttleTime, combineLatest } from 'rxjs';
6
+ import { switchMap, first, tap, map, distinctUntilChanged, shareReplay, of, combineLatestWith, BehaviorSubject, startWith, filter, throttleTime, combineLatest } from 'rxjs';
7
7
  import { filterMaybe, distinctUntilHasDifferentValues, SubscriptionObject, asObservableFromGetter, asObservable } from '@dereekb/rxjs';
8
- import { DateScheduleDayCode, expandDateScheduleDayCodesToDayOfWeekSet, dateTimingRelativeIndexFactory, dateBlockDayOfWeekFactory, findMaxDate, findMinDate, isSameDateRange, isSameDateDay, isSameDate, expandDateScheduleRange, isSameDateScheduleRange, dateTimingRelativeIndexArrayFactory, isInfiniteDateRange, copyDateScheduleDateFilterConfig, dateScheduleDateFilter, dateTimezoneUtcNormal, expandDateScheduleDayCodes, isDateInDateRangeFunction, isDateWithinDateBlockRangeFunction, copyHoursAndMinutesFromDate, dateScheduleEncodedWeek, dateBlockTimingDateFactory, enabledDaysFromDateScheduleDayCodes, dateScheduleDayCodesFromEnabledDays, formatToMonthDayString, dateRange, DateRangeType } from '@dereekb/date';
9
- import { setsAreEquivalent, unique, mergeArrays, iterableToArray, range, toggleInSet, removeFromSet, addToSet, isIndexNumberInIndexRangeFunction, minAndMaxNumber, getDaysOfWeekNames, reduceBooleansWithAnd, mergeObjects, KeyValueTypleValueFilter } from '@dereekb/util';
8
+ import { DateScheduleDayCode, expandDateScheduleDayCodesToDayOfWeekSet, dateTimingRelativeIndexFactory, dateBlockDayOfWeekFactory, findMaxDate, findMinDate, isSameDateRange, isSameDateDay, isSameDate, dateBlockTimingDateFactory, expandDateScheduleRange, formatToISO8601DayString, isSameDateScheduleRange, dateTimingRelativeIndexArrayFactory, isInfiniteDateRange, copyDateScheduleDateFilterConfig, dateScheduleDateFilter, dateTimezoneUtcNormal, expandDateScheduleDayCodes, isDateInDateRangeFunction, isDateWithinDateBlockRangeFunction, copyHoursAndMinutesFromDate, dateScheduleEncodedWeek, enabledDaysFromDateScheduleDayCodes, dateScheduleDayCodesFromEnabledDays, formatToMonthDayString, dateRange, DateRangeType } from '@dereekb/date';
9
+ import { setsAreEquivalent, mapValuesToSet, unique, mergeArrays, iterableToArray, range, toggleInSet, removeFromSet, addToSet, isIndexNumberInIndexRangeFunction, minAndMaxNumber, getDaysOfWeekNames, reduceBooleansWithAnd, mergeObjects, KeyValueTypleValueFilter } from '@dereekb/util';
10
10
  import { ComponentStore } from '@ngrx/component-store';
11
11
  import { startOfDay, endOfDay, isBefore, endOfWeek } from 'date-fns';
12
12
  import * as i1$1 from '@dereekb/dbx-web';
@@ -168,8 +168,13 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
168
168
  this.effectiveTimezone$ = this.state$.pipe(map((x) => (!calendarScheduleStartBeingUsedFromFilter(x) && x.timezone ? x.timezone : undefined)), distinctUntilChanged(), shareReplay(1));
169
169
  this.effectiveTimezoneNormal$ = this.state$.pipe(map((x) => (!calendarScheduleStartBeingUsedFromFilter(x) && x.timezoneNormal ? x.timezoneNormal : undefined)), distinctUntilChanged(), shareReplay(1));
170
170
  this.currentSelectionValue$ = this.state$.pipe(map((x) => x.currentSelectionValue), shareReplay(1));
171
+ this.currentSelectionValueStart$ = this.currentSelectionValue$.pipe(map((x) => x === null || x === void 0 ? void 0 : x.dateScheduleRange.start), distinctUntilChanged(isSameDate), shareReplay(1));
172
+ this.currentSelectionValueDateBlockTimingDateFactory$ = this.currentSelectionValueStart$.pipe(map((start) => (start ? dateBlockTimingDateFactory({ start }) : undefined)), shareReplay(1));
171
173
  this.currentSelectionValueDateBlockDurationSpan$ = this.currentSelectionValue$.pipe(map((x) => (x ? expandDateScheduleRange(x) : [])), shareReplay(1));
172
174
  this.selectionValueSelectedIndexes$ = this.currentSelectionValueDateBlockDurationSpan$.pipe(map((x) => new Set(x.map((y) => y.i))), distinctUntilHasDifferentValues(), shareReplay(1));
175
+ this.selectionValueSelectedDates$ = this.currentSelectionValueDateBlockTimingDateFactory$.pipe(switchMap((dateFactory) => {
176
+ return dateFactory ? this.selectionValueSelectedIndexes$.pipe(map((x) => mapValuesToSet(x, (y) => formatToISO8601DayString(dateFactory(y))))) : of(new Set());
177
+ }), shareReplay(1));
173
178
  this.selectionValue$ = this.currentSelectionValue$.pipe(filterMaybe(), shareReplay(1));
174
179
  this.currentSelectionValueWithTimezone$ = this.currentSelectionValue$.pipe(combineLatestWith(this.effectiveTimezoneNormal$), map(([x, timezoneNormal]) => {
175
180
  if (x && timezoneNormal) {
@@ -496,7 +501,7 @@ function isEnabledDayInCalendarScheduleSelectionState(state) {
496
501
  return (input) => {
497
502
  const index = indexFactory(input);
498
503
  const dayOfWeek = indexDayOfWeek(index);
499
- const isInSelectedRange = isInStartAndEndRange(input);
504
+ const isInSelectedRange = isInStartAndEndRange(index);
500
505
  const isSelected = state.toggledIndexes.has(index);
501
506
  const isAllowedDayOfWeek = allowedDaysOfWeek.has(dayOfWeek);
502
507
  const result = isAllowedDayOfWeek && ((isInSelectedRange && !isSelected) || (isSelected && !isInSelectedRange));