@rivet-health/design-system 10.4.0 → 10.5.0
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/table/state.mjs +7 -1
- package/esm2020/lib/table/table/table.component.mjs +3 -3
- package/fesm2015/rivet-health-design-system.mjs +8 -3
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +8 -2
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/lib/table/state.d.ts +1 -0
- package/package.json +1 -1
|
@@ -44,6 +44,7 @@ export var RivTable;
|
|
|
44
44
|
pages: getPages(s),
|
|
45
45
|
next: getNextPage(s),
|
|
46
46
|
pageCount: getPageCount(s),
|
|
47
|
+
showControls: getShowPaginationControls(s),
|
|
47
48
|
},
|
|
48
49
|
},
|
|
49
50
|
result: {
|
|
@@ -162,6 +163,11 @@ function getNextPage(state) {
|
|
|
162
163
|
const next = state.query.pagination.page + 1;
|
|
163
164
|
return next <= max ? next : null;
|
|
164
165
|
}
|
|
166
|
+
// We don't want to show the pagination controls when they are unnecessary.
|
|
167
|
+
function getShowPaginationControls(state) {
|
|
168
|
+
const smallestPageSize = Math.min(...[...RivTable.pageSizes]);
|
|
169
|
+
return state.result.totalMatchingRowCount > smallestPageSize;
|
|
170
|
+
}
|
|
165
171
|
function getAllColumns(state, supportedColumns) {
|
|
166
172
|
// If the table offers more columns than the user has configuration settings
|
|
167
173
|
// for (or if the user has no configuration settings yet), we'll append them
|
|
@@ -585,4 +591,4 @@ async function* reduce(state, action, columns, source) {
|
|
|
585
591
|
break;
|
|
586
592
|
}
|
|
587
593
|
}
|
|
588
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../projects/riv/src/lib/table/state.ts"],"names":[],"mappings":"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","sourcesContent":["import Fuse, { IFuseOptions } from 'fuse.js';\nimport { defaultsDeep, difference, orderBy, range } from 'lodash';\nimport {\n  Connectable,\n  connectable,\n  from,\n  map,\n  mergeScan,\n  Observable,\n  ReplaySubject,\n  Subject,\n} from 'rxjs';\nimport { DeepPartial } from 'utility-types';\n\nexport namespace RivTable {\n  export type Row = { id: string | number };\n  export type Column = string;\n  export type Filters = any;\n\n  /**\n   * RivTable's state and user actions are divided into the following chunks:\n   *\n   * - Query (for things like filters, pagination, search, etc.)\n   * - Loading (for whether or not the table is loading row data)\n   * - Result (for the row data itself)\n   * - Display (for things like column configuration)\n   * - Selection (for tracking the user's row selections)\n   *\n   * Note that the data flow is unidirectional: the UI issues actions, which\n   * affect the state, and the state gets passed back to the UI for display.\n   *\n   * ┌──────┐\n   * │  UI  ◄────────┐\n   * └──┬───┘        │\n   *    │            │\n   * ┌──▼────────┐   │\n   * │  Actions  │   │\n   * └──┬────────┘   │\n   *    │            │\n   * ┌──▼────────────┴─┐\n   * │  State reducer  │\n   * └─────────────────┘\n   *\n   * From the core state, calculated state is derived and added to the core\n   * state (e.g., from the raw selection state we can determine whether or not\n   * all the rows on the currently displayed page are selected, etc.).\n   */\n\n  ///////////\n  // Query //\n  ///////////\n\n  // Query state //\n\n  export type OrderDirection = 'asc' | 'desc';\n  export const pageSizes = [25, 50, 100, 250] as const;\n  export type Query<C extends Column, F extends Filters> = {\n    order: {\n      direction: OrderDirection;\n      column: C;\n    } | null;\n    search: string;\n    filters: F | null;\n    pagination: {\n      page: number;\n      pageSize: number;\n    };\n  };\n\n  // Query actions //\n\n  export type QueryAction<C extends Column, F extends Filters> =\n    | { type: 'load' }\n    | { type: 'orderChange'; payload: Query<C, F>['order'] }\n    | { type: 'orderColumnToggle'; column: C }\n    | { type: 'searchChange'; payload: Query<C, F>['search'] }\n    | { type: 'filtersChange'; payload: Query<C, F>['filters'] }\n    | { type: 'paginationChange'; payload: Query<C, F>['pagination'] }\n    | { type: 'nextPageNavigate' }\n    | { type: 'previousPageNavigate' }\n    | { type: 'pageChange'; page: number }\n    | { type: 'pageSizeChange'; size: number };\n\n  //////////\n  // Load //\n  //////////\n\n  export type Load = {\n    loading: boolean;\n    error: unknown | null;\n  };\n\n  ////////////\n  // Result //\n  ////////////\n\n  export type Result<R extends Row> = {\n    /**\n     * The full row data for the current page, after filters, search query, and\n     * row ordering are applied.\n     */\n    currentPageData: R[];\n    /**\n     * The total number of rows (regardless of pagination) that match the\n     * filters and search query.\n     */\n    totalMatchingRowCount: number;\n  };\n  export type Source<R extends Row, C extends Column, F extends Filters> = (\n    query: RivTable.Query<C, F>,\n    mostRecentAction: RivTable.Action<R, C, F>,\n  ) => Promise<Result<R>>;\n\n  /////////////\n  // Display //\n  /////////////\n\n  // Display state //\n\n  export type ColumnSettings<C extends Column> = {\n    name: C;\n    enabled: boolean;\n    preferredWidth: number | 'auto';\n    pinned: boolean;\n  };\n  export type Display<C extends Column> = {\n    columnSettings: ColumnSettings<C>[];\n  };\n\n  // Display actions //\n\n  export type DisplayAction<C extends Column> =\n    | { type: 'columnSettingsChange'; payload: Display<C>['columnSettings'] }\n    | {\n        type: 'columnPinChange';\n        column: C;\n        pinned: boolean;\n      }\n    | {\n        type: 'columnOrderChange';\n        previousIndex: number;\n        newIndex: number;\n      }\n    | {\n        type: 'columnEnabledChange';\n        column: C;\n        enabled: boolean;\n      }\n    | {\n        type: 'columnWidthChange';\n        column: C;\n        preferredWidth: number | 'auto';\n      };\n\n  ///////////////\n  // Selection //\n  ///////////////\n\n  // Selection state //\n\n  export type Selection<R extends Row> =\n    | {\n        mode: 'include';\n        included: Set<R['id']>;\n      }\n    | {\n        mode: 'exclude';\n        excluded: Set<R['id']>;\n      };\n\n  // Selection actions //\n\n  export type SelectionAction<R extends Row> =\n    | {\n        type: 'selectionChange';\n        payload: Selection<R>;\n      }\n    | {\n        type: 'rowSelectedChange';\n        id: R['id'];\n        selected: boolean;\n      }\n    | {\n        type: 'pageSelectedChange';\n      }\n    | {\n        type: 'allSelectedChange';\n      };\n\n  /////////////////////////////\n  // Putting it all together //\n  /////////////////////////////\n\n  // Combined state //\n\n  export type CoreState<R extends Row, C extends Column, F extends Filters> = {\n    query: Query<C, F>;\n    load: Load;\n    result: Result<R>;\n    display: Display<C>;\n    selection: Selection<R>;\n  };\n\n  // Combined actions //\n\n  export type Action<R extends Row, C extends Column, F extends Filters> =\n    | QueryAction<C, F>\n    | DisplayAction<C>\n    | SelectionAction<R>;\n\n  // Full state (core state plus pure derivations) //\n\n  export type ColumnDataType =\n    | 'advanced'\n    | 'currency'\n    | 'date'\n    | 'icon'\n    | 'longText'\n    | 'number'\n    | 'shortText';\n  export type ColumnAlignment = 'left' | 'center' | 'right';\n  export type ColumnMetadata = {\n    orderable: boolean;\n    minWidth: number;\n    dataType: ColumnDataType;\n    description?: string;\n  };\n  export type FullRow<R extends Row> = R & {\n    rowLink: string | null;\n    selected: boolean;\n  };\n  export type FullColumn<C extends Column> = ColumnSettings<C> &\n    ColumnMetadata & {\n      width: number;\n      left: number | null;\n      alignment: ColumnAlignment;\n    };\n  export type MultiSelectionState = boolean | 'indeterminate';\n\n  export type CsvCellFormatter<R extends Row, C extends Column> = (\n    row: R,\n    column: FullColumn<C>,\n  ) => string;\n  export type CsvRow = string[];\n  export type Csv = CsvRow[];\n  export type CsvOutput =\n    | { loading: true; data: null }\n    | { loading: false; data: Csv };\n\n  export type FullState<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  > = CoreState<R, C, F> & {\n    query: {\n      pagination: {\n        previous: number | null;\n        pages: number[];\n        next: number | null;\n        pageCount: number;\n      };\n    };\n    result: {\n      rows: FullRow<R>[];\n      csvData: () => AsyncGenerator<CsvOutput>;\n      csvFilename: string;\n    };\n    display: {\n      columns: FullColumn<C>[];\n      zeroStateMessage: string | null;\n    };\n    selection: {\n      isAllSelected: MultiSelectionState;\n      isCurrentPageSelected: MultiSelectionState;\n      selectedCount: number;\n    };\n  };\n\n  /**\n   * The manager is what sets up the initial state and translates user actions\n   * (like pagination or filter changes, etc.) into new row data by calling the\n   * reducer function. It also augments the core state with additional derived\n   * state.\n   */\n\n  export type Manager<R extends Row, C extends Column, F extends Filters> = {\n    actions: Subject<Action<R, C, F>>;\n    state: Connectable<FullState<R, C, F>>;\n  };\n\n  export type ManagerOptions<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  > = {\n    initialState?: DeepPartial<CoreState<R, C, F>>;\n    rowLink?: (row: R) => string;\n    csvCellFormatter?: CsvCellFormatter<R, C>;\n    csvFileBasename?: string;\n  };\n\n  export function createManager<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  >(\n    source: Source<R, C, F>,\n    columns: Map<C, ColumnMetadata>,\n    pluralEntityName: string,\n    options?: ManagerOptions<R, C, F>,\n  ): Manager<R, C, F> {\n    // Set up the initial table state.\n    const defaultState: CoreState<R, C, F> = {\n      query: {\n        order: null,\n        search: '',\n        pagination: {\n          page: 0,\n          pageSize: 25,\n        },\n        filters: null,\n      },\n      load: { loading: false, error: null },\n      result: {\n        currentPageData: [],\n        totalMatchingRowCount: 0,\n      },\n      display: {\n        columnSettings: [],\n      },\n      selection: {\n        mode: 'include',\n        included: new Set(),\n      },\n    };\n    const defaultedInitialState: CoreState<R, C, F> = defaultsDeep(\n      {},\n      options?.initialState,\n      defaultState,\n    );\n\n    // Wire up reduced state from actions and initial state.\n    const actions: Subject<Action<R, C, F>> = new Subject();\n    const coreState: Observable<CoreState<R, C, F>> = actions.pipe(\n      mergeScan(\n        (state, action) => from(reduce(state, action, columns, source)),\n        defaultedInitialState,\n        1,\n      ),\n    );\n\n    // Augment state with derived state, and subscribe.\n    const state: Connectable<FullState<R, C, F>> = connectable(\n      coreState.pipe(\n        map(s => ({\n          ...s,\n          query: {\n            ...s.query,\n            pagination: {\n              ...s.query.pagination,\n              previous: getPreviousPage(s),\n              pages: getPages(s),\n              next: getNextPage(s),\n              pageCount: getPageCount(s),\n            },\n          },\n          result: {\n            ...s.result,\n            rows: s.result.currentPageData.map(row => ({\n              ...row,\n              rowLink: options?.rowLink ? options.rowLink(row) : null,\n              selected: isRowSelected(s, row.id),\n            })),\n            csvData: async function* () {\n              const cellFormatter = options?.csvCellFormatter;\n              if (!cellFormatter)\n                throw new Error(\n                  'options.csvCellFormatter is required for CSV export',\n                );\n              yield { loading: true, data: null };\n              const dataSet = await source(\n                {\n                  ...s.query,\n                  pagination: {\n                    page: 0,\n                    pageSize: s.result.totalMatchingRowCount,\n                  },\n                },\n                { type: 'load' },\n              );\n              const fullColumns = resolveColumns(s, columns);\n              const data: Csv = [\n                fullColumns.map(({ name }) => name),\n                ...dataSet.currentPageData.map(record =>\n                  fullColumns.map(column => cellFormatter(record, column)),\n                ),\n              ];\n              yield { loading: false, data };\n            },\n            csvFilename:\n              (options?.csvFileBasename?.slice(0, 200) ?? pluralEntityName) +\n              '.csv',\n          },\n          display: {\n            ...s.display,\n            columns: resolveColumns(s, columns),\n            zeroStateMessage: getZeroStateMessage(s, pluralEntityName),\n          },\n          selection: {\n            ...s.selection,\n            isAllSelected: isAllSelected(s),\n            isCurrentPageSelected: isCurrentPageSelected(s),\n            selectedCount: selectedCount(s),\n          },\n        })),\n      ),\n      {\n        connector: () => new ReplaySubject(1),\n        resetOnDisconnect: false,\n      },\n    );\n    state.connect();\n\n    // Load initial table row data.\n    actions.next({ type: 'load' });\n\n    return { actions, state };\n  }\n\n  /**\n   * Most tables use remote backends to fetch data asynchronously, but an\n   * in-memory source is useful for small datasets, when RivTable features like\n   * ordering and pagination are desired.\n   */\n\n  export type InMemoryColumnMetadata<R extends Row> = Omit<\n    ColumnMetadata,\n    'orderable'\n  > & { orderKey?: keyof R };\n\n  export type InMemoryManagerOptions<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  > = ManagerOptions<R, C, F> & {\n    fuseOptions?: IFuseOptions<R>;\n    filter?: (filters: F | null, row: R) => boolean;\n  };\n\n  export function createInMemoryManager<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  >(\n    fetchDataset: () => Promise<R[]> | R[],\n    columns: Map<C, InMemoryColumnMetadata<R>>,\n    pluralEntityName: string,\n    options?: InMemoryManagerOptions<R, C, F>,\n  ): Manager<R, C, F> {\n    let data: R[];\n    let fuse: Fuse<R>;\n\n    const source: Source<R, C, F> = async (query, mostRecentAction) => {\n      if (mostRecentAction.type === 'load') {\n        data = await fetchDataset();\n        fuse = new Fuse(data, options?.fuseOptions);\n      }\n      const orderColumn: keyof R | undefined = query.order\n        ? columns.get(query.order.column)?.orderKey\n        : undefined;\n      const ordered = query.search\n        ? fuse.search(query.search).map(result => result.item)\n        : query.order && orderColumn\n        ? orderBy(data, orderColumn, query.order.direction)\n        : data;\n      const filter = options?.filter;\n      const filtered = filter\n        ? ordered.filter(row => filter(query.filters, row))\n        : ordered;\n      const startIdx = query.pagination.pageSize * query.pagination.page;\n      const endIdx = startIdx + query.pagination.pageSize;\n      const paginated = filtered.slice(startIdx, endIdx);\n      return {\n        currentPageData: paginated,\n        totalMatchingRowCount: filtered.length,\n      };\n    };\n    const columnMetadata: Map<C, ColumnMetadata> = new Map(\n      [...columns.entries()].map(([name, metadata]) => [\n        name,\n        {\n          orderable: !!metadata.orderKey,\n          description: metadata.description,\n          minWidth: metadata.minWidth,\n          dataType: metadata.dataType,\n        },\n      ]),\n    );\n    return createManager(source, columnMetadata, pluralEntityName, options);\n  }\n}\n\nfunction getPageCount<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number {\n  return Math.max(\n    Math.ceil(\n      state.result.totalMatchingRowCount / state.query.pagination.pageSize,\n    ),\n    1,\n  );\n}\n\nfunction getPreviousPage<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number | null {\n  return state.query.pagination.page === 0\n    ? null\n    : state.query.pagination.page - 1;\n}\n\nfunction getPages<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number[] {\n  const padding = 4;\n  const min = 0;\n  const max = getPageCount(state) - 1;\n  const desiredStart = state.query.pagination.page - padding;\n  const clampedStart = Math.max(min, desiredStart);\n  const desiredEnd = state.query.pagination.page + padding;\n  const clampedEnd = Math.min(max, desiredEnd);\n  const start = Math.max(min, clampedStart - (desiredEnd - clampedEnd));\n  const end = Math.min(max, clampedEnd + (clampedStart - desiredStart));\n  return range(start, end + 1);\n}\n\nfunction getNextPage<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number | null {\n  const max = getPageCount(state) - 1;\n  const next = state.query.pagination.page + 1;\n  return next <= max ? next : null;\n}\n\nfunction getAllColumns<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  supportedColumns: Map<C, RivTable.ColumnMetadata>,\n): RivTable.ColumnSettings<C>[] {\n  // If the table offers more columns than the user has configuration settings\n  // for (or if the user has no configuration settings yet), we'll append them\n  // to the end. This ensures that new columns we add to existing tables over\n  // time (1) get displayed even though they don't appear in the user's\n  // configuration settings yet, and (2) don't interrupt their existing setup.\n  const columnNamesWithoutUserSettings = difference(\n    [...supportedColumns.keys()],\n    state.display.columnSettings.map(({ name }) => name),\n  );\n\n  // Throw out settings for columns no longer offered by the table.\n  const columnsWithUserSettings: RivTable.ColumnSettings<C>[] =\n    state.display.columnSettings.filter(({ name }) =>\n      supportedColumns.has(name),\n    );\n\n  const columnsWithoutUserSettings: RivTable.ColumnSettings<C>[] = [\n    ...columnNamesWithoutUserSettings,\n  ].map((name: C) => ({\n    name,\n    enabled: true,\n    preferredWidth: 'auto',\n    pinned: false,\n  }));\n\n  return [...columnsWithUserSettings, ...columnsWithoutUserSettings];\n}\n\nfunction getAlignment(\n  metadata: RivTable.ColumnMetadata,\n  index: number,\n): RivTable.ColumnAlignment {\n  if (index === 0) return 'left';\n  switch (metadata.dataType) {\n    case 'date':\n    case 'longText':\n      return 'left';\n    case 'advanced':\n    case 'icon':\n    case 'shortText':\n      return 'center';\n    case 'currency':\n    case 'number':\n      return 'right';\n  }\n}\n\nfunction resolveColumns<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  supportedColumns: Map<C, RivTable.ColumnMetadata>,\n): RivTable.FullColumn<C>[] {\n  const allColumns = getAllColumns(state, supportedColumns);\n  return allColumns\n    .filter(({ enabled }) => enabled)\n    .reduce(\n      (\n        fullColumns: RivTable.FullColumn<C>[],\n        settings: RivTable.ColumnSettings<C>,\n        i: number,\n      ): RivTable.FullColumn<C>[] => {\n        const metadata = supportedColumns.get(settings.name)!;\n        const resolvedWidth =\n          settings.preferredWidth === 'auto'\n            ? metadata.minWidth\n            : Math.max(metadata.minWidth, settings.preferredWidth);\n        const previousColumn: RivTable.FullColumn<C> | undefined =\n          fullColumns[i - 1];\n        return [\n          ...fullColumns,\n          {\n            ...settings,\n            ...metadata,\n            width: resolvedWidth,\n            left: settings.pinned\n              ? previousColumn\n                ? (previousColumn.left || 0) + previousColumn.width\n                : 0\n              : null,\n            alignment: getAlignment(metadata, i),\n          },\n        ];\n      },\n      [],\n    );\n}\n\nfunction getZeroStateMessage<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>, entity: string): string | null {\n  if (state.result.totalMatchingRowCount > 0) return null;\n  if (state.query.search)\n    return `No ${entity} match your current search keyword.`;\n  if (state.query.filters) return `No ${entity} match your current filters.`;\n  return `No ${entity}.`;\n}\n\nfunction changeColumnPin<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  column: C,\n  pinned: boolean,\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: orderBy(\n        allColumns.map(c => ({\n          ...c,\n          pinned: c.name === column ? pinned : c.pinned,\n        })),\n        v => (v.pinned ? 1 : 0),\n        'desc',\n      ),\n    },\n  };\n}\n\nfunction changeColumnOrder<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  previousIndex: number,\n  newIndex: number,\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n\n  // First, put the columns in the desired order.\n  const item = allColumns[previousIndex];\n  const withoutItem = allColumns.filter((_, i) => i !== previousIndex);\n  const reordered = [\n    ...withoutItem.slice(0, newIndex),\n    item,\n    ...withoutItem.slice(newIndex),\n  ];\n\n  // Then, we may need to fix the pins (all pinned columns appear at the\n  // beginning of the columns array) since the user is allowed to drag\n  // and drop columns to and from the pinned area. If the user drags a\n  // column across that threshold, update its pinned status.\n  const updated = reordered.map((settings, i, arr) => {\n    if (newIndex === i) {\n      return {\n        ...settings,\n        pinned: settings.pinned\n          ? arr[i - 1]?.pinned ?? true\n          : arr[i + 1]?.pinned ?? false,\n      };\n    } else return settings;\n  });\n\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: updated,\n    },\n  };\n}\n\nfunction changeColumnEnabled<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  column: C,\n  enabled: boolean,\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: allColumns.map(c => ({\n        ...c,\n        enabled: c.name === column ? enabled : c.enabled,\n      })),\n    },\n  };\n}\n\nfunction changeColumnWidth<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  column: C,\n  preferredWidth: RivTable.ColumnSettings<C>['preferredWidth'],\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: allColumns.map(c => ({\n        ...c,\n        preferredWidth: c.name === column ? preferredWidth : c.preferredWidth,\n      })),\n    },\n  };\n}\n\nfunction isRowSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>, id: R['id']): boolean {\n  switch (state.selection.mode) {\n    case 'include':\n      return state.selection.included.has(id);\n    case 'exclude':\n      return !state.selection.excluded.has(id);\n  }\n}\n\nfunction isAllSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.MultiSelectionState {\n  if (\n    (state.selection.mode === 'exclude' &&\n      state.selection.excluded.size === 0) ||\n    (state.selection.mode === 'include' &&\n      state.selection.included.size === state.result.totalMatchingRowCount)\n  )\n    return true;\n  if (\n    (state.selection.mode === 'exclude' &&\n      state.selection.excluded.size === state.result.totalMatchingRowCount) ||\n    (state.selection.mode === 'include' && state.selection.included.size === 0)\n  )\n    return false;\n  return 'indeterminate';\n}\n\nfunction isCurrentPageSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.MultiSelectionState {\n  const selectedStates = state.result.currentPageData.map(({ id }) =>\n    isRowSelected(state, id),\n  );\n  if (selectedStates.length > 0) {\n    if (selectedStates.every(v => v)) return true;\n    if (selectedStates.some(v => v)) return 'indeterminate';\n  }\n  return false;\n}\n\nfunction selectedCount<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number {\n  switch (state.selection.mode) {\n    case 'include':\n      return state.selection.included.size;\n    case 'exclude':\n      return state.result.totalMatchingRowCount - state.selection.excluded.size;\n  }\n}\n\nasync function* refreshResultWith<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  source: RivTable.Source<R, C, F>,\n  mostRecentAction: RivTable.Action<R, C, F>,\n): AsyncGenerator<RivTable.CoreState<R, C, F>> {\n  yield {\n    ...state,\n    load: {\n      loading: true,\n      error: null,\n    },\n  };\n  try {\n    const result = await source(state.query, mostRecentAction);\n    yield {\n      ...state,\n      load: {\n        loading: false,\n        error: null,\n      },\n      result,\n    };\n  } catch (error) {\n    yield {\n      ...state,\n      load: {\n        loading: false,\n        error,\n      },\n    };\n  }\n}\n\nfunction setRowSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  id: R['id'],\n  selected: boolean,\n): RivTable.CoreState<R, C, F> {\n  return {\n    ...state,\n    selection:\n      state.selection.mode === 'include'\n        ? {\n            mode: 'include',\n            included: selected\n              ? new Set([...state.selection.included, id])\n              : new Set([...state.selection.included].filter(s => s !== id)),\n          }\n        : {\n            mode: 'exclude',\n            excluded: selected\n              ? new Set([...state.selection.excluded].filter(s => s !== id))\n              : new Set([...state.selection.excluded, id]),\n          },\n  };\n}\n\nfunction togglePageSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.CoreState<R, C, F> {\n  const isPageFullySelected = state.result.currentPageData.every(({ id }) =>\n    isRowSelected(state, id),\n  );\n  return state.result.currentPageData.reduce((accumulatedState, row) => {\n    return setRowSelected(accumulatedState, row.id, !isPageFullySelected);\n  }, state);\n}\n\nfunction toggleAllSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.CoreState<R, C, F> {\n  if (isAllSelected(state) === true) {\n    return {\n      ...state,\n      selection: {\n        mode: 'include',\n        included: new Set(),\n      },\n    };\n  } else {\n    return {\n      ...state,\n      selection: {\n        mode: 'exclude',\n        excluded: new Set(),\n      },\n    };\n  }\n}\n\nfunction toggleColumnOrder<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>, column: C): RivTable.CoreState<R, C, F> {\n  if (state.query.order?.column === column) {\n    return {\n      ...state,\n      query: {\n        ...state.query,\n        order:\n          state.query.order.direction === 'asc'\n            ? {\n                column,\n                direction: 'desc',\n              }\n            : null,\n      },\n    };\n  }\n  return {\n    ...state,\n    query: {\n      ...state.query,\n      order: {\n        column,\n        direction: 'asc',\n      },\n    },\n  };\n}\n\nasync function* reduce<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  action: RivTable.Action<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  source: RivTable.Source<R, C, F>,\n): AsyncGenerator<RivTable.CoreState<R, C, F>> {\n  switch (action.type) {\n    case 'load':\n      yield* refreshResultWith(state, source, action);\n      break;\n    case 'orderChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            order: action.payload,\n          },\n          selection: {\n            mode: 'include',\n            included: new Set(),\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'orderColumnToggle':\n      yield* refreshResultWith(\n        toggleColumnOrder(state, action.column),\n        source,\n        action,\n      );\n      break;\n    case 'searchChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            search: action.payload,\n          },\n          selection: {\n            mode: 'include',\n            included: new Set(),\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'paginationChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: action.payload,\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'previousPageNavigate':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              page: getPreviousPage(state) ?? 0,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'nextPageNavigate':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              page: getNextPage(state) ?? getPageCount(state) - 1,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'pageChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              page: action.page,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'pageSizeChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              pageSize: action.size,\n              page: 0,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'filtersChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            filters: action.payload,\n          },\n          selection: {\n            mode: 'include',\n            included: new Set(),\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'columnSettingsChange':\n      yield {\n        ...state,\n        display: {\n          ...state.display,\n          columnSettings: action.payload,\n        },\n      };\n      break;\n    case 'columnPinChange':\n      yield changeColumnPin(state, columns, action.column, action.pinned);\n      break;\n    case 'columnOrderChange':\n      yield changeColumnOrder(\n        state,\n        columns,\n        action.previousIndex,\n        action.newIndex,\n      );\n      break;\n    case 'columnEnabledChange':\n      yield changeColumnEnabled(state, columns, action.column, action.enabled);\n      break;\n    case 'columnWidthChange':\n      yield changeColumnWidth(\n        state,\n        columns,\n        action.column,\n        action.preferredWidth,\n      );\n      break;\n    case 'selectionChange':\n      yield {\n        ...state,\n        selection: action.payload,\n      };\n      break;\n    case 'rowSelectedChange':\n      yield setRowSelected(state, action.id, action.selected);\n      break;\n    case 'pageSelectedChange':\n      yield togglePageSelected(state);\n      break;\n    case 'allSelectedChange':\n      yield toggleAllSelected(state);\n      break;\n  }\n}\n"]}
|
|
594
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../projects/riv/src/lib/table/state.ts"],"names":[],"mappings":"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","sourcesContent":["import Fuse, { IFuseOptions } from 'fuse.js';\nimport { defaultsDeep, difference, orderBy, range } from 'lodash';\nimport {\n  Connectable,\n  connectable,\n  from,\n  map,\n  mergeScan,\n  Observable,\n  ReplaySubject,\n  Subject,\n} from 'rxjs';\nimport { DeepPartial } from 'utility-types';\n\nexport namespace RivTable {\n  export type Row = { id: string | number };\n  export type Column = string;\n  export type Filters = any;\n\n  /**\n   * RivTable's state and user actions are divided into the following chunks:\n   *\n   * - Query (for things like filters, pagination, search, etc.)\n   * - Loading (for whether or not the table is loading row data)\n   * - Result (for the row data itself)\n   * - Display (for things like column configuration)\n   * - Selection (for tracking the user's row selections)\n   *\n   * Note that the data flow is unidirectional: the UI issues actions, which\n   * affect the state, and the state gets passed back to the UI for display.\n   *\n   * ┌──────┐\n   * │  UI  ◄────────┐\n   * └──┬───┘        │\n   *    │            │\n   * ┌──▼────────┐   │\n   * │  Actions  │   │\n   * └──┬────────┘   │\n   *    │            │\n   * ┌──▼────────────┴─┐\n   * │  State reducer  │\n   * └─────────────────┘\n   *\n   * From the core state, calculated state is derived and added to the core\n   * state (e.g., from the raw selection state we can determine whether or not\n   * all the rows on the currently displayed page are selected, etc.).\n   */\n\n  ///////////\n  // Query //\n  ///////////\n\n  // Query state //\n\n  export type OrderDirection = 'asc' | 'desc';\n  export const pageSizes = [25, 50, 100, 250] as const;\n  export type Query<C extends Column, F extends Filters> = {\n    order: {\n      direction: OrderDirection;\n      column: C;\n    } | null;\n    search: string;\n    filters: F | null;\n    pagination: {\n      page: number;\n      pageSize: number;\n    };\n  };\n\n  // Query actions //\n\n  export type QueryAction<C extends Column, F extends Filters> =\n    | { type: 'load' }\n    | { type: 'orderChange'; payload: Query<C, F>['order'] }\n    | { type: 'orderColumnToggle'; column: C }\n    | { type: 'searchChange'; payload: Query<C, F>['search'] }\n    | { type: 'filtersChange'; payload: Query<C, F>['filters'] }\n    | { type: 'paginationChange'; payload: Query<C, F>['pagination'] }\n    | { type: 'nextPageNavigate' }\n    | { type: 'previousPageNavigate' }\n    | { type: 'pageChange'; page: number }\n    | { type: 'pageSizeChange'; size: number };\n\n  //////////\n  // Load //\n  //////////\n\n  export type Load = {\n    loading: boolean;\n    error: unknown | null;\n  };\n\n  ////////////\n  // Result //\n  ////////////\n\n  export type Result<R extends Row> = {\n    /**\n     * The full row data for the current page, after filters, search query, and\n     * row ordering are applied.\n     */\n    currentPageData: R[];\n    /**\n     * The total number of rows (regardless of pagination) that match the\n     * filters and search query.\n     */\n    totalMatchingRowCount: number;\n  };\n  export type Source<R extends Row, C extends Column, F extends Filters> = (\n    query: RivTable.Query<C, F>,\n    mostRecentAction: RivTable.Action<R, C, F>,\n  ) => Promise<Result<R>>;\n\n  /////////////\n  // Display //\n  /////////////\n\n  // Display state //\n\n  export type ColumnSettings<C extends Column> = {\n    name: C;\n    enabled: boolean;\n    preferredWidth: number | 'auto';\n    pinned: boolean;\n  };\n  export type Display<C extends Column> = {\n    columnSettings: ColumnSettings<C>[];\n  };\n\n  // Display actions //\n\n  export type DisplayAction<C extends Column> =\n    | { type: 'columnSettingsChange'; payload: Display<C>['columnSettings'] }\n    | {\n        type: 'columnPinChange';\n        column: C;\n        pinned: boolean;\n      }\n    | {\n        type: 'columnOrderChange';\n        previousIndex: number;\n        newIndex: number;\n      }\n    | {\n        type: 'columnEnabledChange';\n        column: C;\n        enabled: boolean;\n      }\n    | {\n        type: 'columnWidthChange';\n        column: C;\n        preferredWidth: number | 'auto';\n      };\n\n  ///////////////\n  // Selection //\n  ///////////////\n\n  // Selection state //\n\n  export type Selection<R extends Row> =\n    | {\n        mode: 'include';\n        included: Set<R['id']>;\n      }\n    | {\n        mode: 'exclude';\n        excluded: Set<R['id']>;\n      };\n\n  // Selection actions //\n\n  export type SelectionAction<R extends Row> =\n    | {\n        type: 'selectionChange';\n        payload: Selection<R>;\n      }\n    | {\n        type: 'rowSelectedChange';\n        id: R['id'];\n        selected: boolean;\n      }\n    | {\n        type: 'pageSelectedChange';\n      }\n    | {\n        type: 'allSelectedChange';\n      };\n\n  /////////////////////////////\n  // Putting it all together //\n  /////////////////////////////\n\n  // Combined state //\n\n  export type CoreState<R extends Row, C extends Column, F extends Filters> = {\n    query: Query<C, F>;\n    load: Load;\n    result: Result<R>;\n    display: Display<C>;\n    selection: Selection<R>;\n  };\n\n  // Combined actions //\n\n  export type Action<R extends Row, C extends Column, F extends Filters> =\n    | QueryAction<C, F>\n    | DisplayAction<C>\n    | SelectionAction<R>;\n\n  // Full state (core state plus pure derivations) //\n\n  export type ColumnDataType =\n    | 'advanced'\n    | 'currency'\n    | 'date'\n    | 'icon'\n    | 'longText'\n    | 'number'\n    | 'shortText';\n  export type ColumnAlignment = 'left' | 'center' | 'right';\n  export type ColumnMetadata = {\n    orderable: boolean;\n    minWidth: number;\n    dataType: ColumnDataType;\n    description?: string;\n  };\n  export type FullRow<R extends Row> = R & {\n    rowLink: string | null;\n    selected: boolean;\n  };\n  export type FullColumn<C extends Column> = ColumnSettings<C> &\n    ColumnMetadata & {\n      width: number;\n      left: number | null;\n      alignment: ColumnAlignment;\n    };\n  export type MultiSelectionState = boolean | 'indeterminate';\n\n  export type CsvCellFormatter<R extends Row, C extends Column> = (\n    row: R,\n    column: FullColumn<C>,\n  ) => string;\n  export type CsvRow = string[];\n  export type Csv = CsvRow[];\n  export type CsvOutput =\n    | { loading: true; data: null }\n    | { loading: false; data: Csv };\n\n  export type FullState<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  > = CoreState<R, C, F> & {\n    query: {\n      pagination: {\n        previous: number | null;\n        pages: number[];\n        next: number | null;\n        pageCount: number;\n        showControls: boolean;\n      };\n    };\n    result: {\n      rows: FullRow<R>[];\n      csvData: () => AsyncGenerator<CsvOutput>;\n      csvFilename: string;\n    };\n    display: {\n      columns: FullColumn<C>[];\n      zeroStateMessage: string | null;\n    };\n    selection: {\n      isAllSelected: MultiSelectionState;\n      isCurrentPageSelected: MultiSelectionState;\n      selectedCount: number;\n    };\n  };\n\n  /**\n   * The manager is what sets up the initial state and translates user actions\n   * (like pagination or filter changes, etc.) into new row data by calling the\n   * reducer function. It also augments the core state with additional derived\n   * state.\n   */\n\n  export type Manager<R extends Row, C extends Column, F extends Filters> = {\n    actions: Subject<Action<R, C, F>>;\n    state: Connectable<FullState<R, C, F>>;\n  };\n\n  export type ManagerOptions<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  > = {\n    initialState?: DeepPartial<CoreState<R, C, F>>;\n    rowLink?: (row: R) => string;\n    csvCellFormatter?: CsvCellFormatter<R, C>;\n    csvFileBasename?: string;\n  };\n\n  export function createManager<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  >(\n    source: Source<R, C, F>,\n    columns: Map<C, ColumnMetadata>,\n    pluralEntityName: string,\n    options?: ManagerOptions<R, C, F>,\n  ): Manager<R, C, F> {\n    // Set up the initial table state.\n    const defaultState: CoreState<R, C, F> = {\n      query: {\n        order: null,\n        search: '',\n        pagination: {\n          page: 0,\n          pageSize: 25,\n        },\n        filters: null,\n      },\n      load: { loading: false, error: null },\n      result: {\n        currentPageData: [],\n        totalMatchingRowCount: 0,\n      },\n      display: {\n        columnSettings: [],\n      },\n      selection: {\n        mode: 'include',\n        included: new Set(),\n      },\n    };\n    const defaultedInitialState: CoreState<R, C, F> = defaultsDeep(\n      {},\n      options?.initialState,\n      defaultState,\n    );\n\n    // Wire up reduced state from actions and initial state.\n    const actions: Subject<Action<R, C, F>> = new Subject();\n    const coreState: Observable<CoreState<R, C, F>> = actions.pipe(\n      mergeScan(\n        (state, action) => from(reduce(state, action, columns, source)),\n        defaultedInitialState,\n        1,\n      ),\n    );\n\n    // Augment state with derived state, and subscribe.\n    const state: Connectable<FullState<R, C, F>> = connectable(\n      coreState.pipe(\n        map(s => ({\n          ...s,\n          query: {\n            ...s.query,\n            pagination: {\n              ...s.query.pagination,\n              previous: getPreviousPage(s),\n              pages: getPages(s),\n              next: getNextPage(s),\n              pageCount: getPageCount(s),\n              showControls: getShowPaginationControls(s),\n            },\n          },\n          result: {\n            ...s.result,\n            rows: s.result.currentPageData.map(row => ({\n              ...row,\n              rowLink: options?.rowLink ? options.rowLink(row) : null,\n              selected: isRowSelected(s, row.id),\n            })),\n            csvData: async function* () {\n              const cellFormatter = options?.csvCellFormatter;\n              if (!cellFormatter)\n                throw new Error(\n                  'options.csvCellFormatter is required for CSV export',\n                );\n              yield { loading: true, data: null };\n              const dataSet = await source(\n                {\n                  ...s.query,\n                  pagination: {\n                    page: 0,\n                    pageSize: s.result.totalMatchingRowCount,\n                  },\n                },\n                { type: 'load' },\n              );\n              const fullColumns = resolveColumns(s, columns);\n              const data: Csv = [\n                fullColumns.map(({ name }) => name),\n                ...dataSet.currentPageData.map(record =>\n                  fullColumns.map(column => cellFormatter(record, column)),\n                ),\n              ];\n              yield { loading: false, data };\n            },\n            csvFilename:\n              (options?.csvFileBasename?.slice(0, 200) ?? pluralEntityName) +\n              '.csv',\n          },\n          display: {\n            ...s.display,\n            columns: resolveColumns(s, columns),\n            zeroStateMessage: getZeroStateMessage(s, pluralEntityName),\n          },\n          selection: {\n            ...s.selection,\n            isAllSelected: isAllSelected(s),\n            isCurrentPageSelected: isCurrentPageSelected(s),\n            selectedCount: selectedCount(s),\n          },\n        })),\n      ),\n      {\n        connector: () => new ReplaySubject(1),\n        resetOnDisconnect: false,\n      },\n    );\n    state.connect();\n\n    // Load initial table row data.\n    actions.next({ type: 'load' });\n\n    return { actions, state };\n  }\n\n  /**\n   * Most tables use remote backends to fetch data asynchronously, but an\n   * in-memory source is useful for small datasets, when RivTable features like\n   * ordering and pagination are desired.\n   */\n\n  export type InMemoryColumnMetadata<R extends Row> = Omit<\n    ColumnMetadata,\n    'orderable'\n  > & { orderKey?: keyof R };\n\n  export type InMemoryManagerOptions<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  > = ManagerOptions<R, C, F> & {\n    fuseOptions?: IFuseOptions<R>;\n    filter?: (filters: F | null, row: R) => boolean;\n  };\n\n  export function createInMemoryManager<\n    R extends Row,\n    C extends Column,\n    F extends Filters,\n  >(\n    fetchDataset: () => Promise<R[]> | R[],\n    columns: Map<C, InMemoryColumnMetadata<R>>,\n    pluralEntityName: string,\n    options?: InMemoryManagerOptions<R, C, F>,\n  ): Manager<R, C, F> {\n    let data: R[];\n    let fuse: Fuse<R>;\n\n    const source: Source<R, C, F> = async (query, mostRecentAction) => {\n      if (mostRecentAction.type === 'load') {\n        data = await fetchDataset();\n        fuse = new Fuse(data, options?.fuseOptions);\n      }\n      const orderColumn: keyof R | undefined = query.order\n        ? columns.get(query.order.column)?.orderKey\n        : undefined;\n      const ordered = query.search\n        ? fuse.search(query.search).map(result => result.item)\n        : query.order && orderColumn\n        ? orderBy(data, orderColumn, query.order.direction)\n        : data;\n      const filter = options?.filter;\n      const filtered = filter\n        ? ordered.filter(row => filter(query.filters, row))\n        : ordered;\n      const startIdx = query.pagination.pageSize * query.pagination.page;\n      const endIdx = startIdx + query.pagination.pageSize;\n      const paginated = filtered.slice(startIdx, endIdx);\n      return {\n        currentPageData: paginated,\n        totalMatchingRowCount: filtered.length,\n      };\n    };\n    const columnMetadata: Map<C, ColumnMetadata> = new Map(\n      [...columns.entries()].map(([name, metadata]) => [\n        name,\n        {\n          orderable: !!metadata.orderKey,\n          description: metadata.description,\n          minWidth: metadata.minWidth,\n          dataType: metadata.dataType,\n        },\n      ]),\n    );\n    return createManager(source, columnMetadata, pluralEntityName, options);\n  }\n}\n\nfunction getPageCount<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number {\n  return Math.max(\n    Math.ceil(\n      state.result.totalMatchingRowCount / state.query.pagination.pageSize,\n    ),\n    1,\n  );\n}\n\nfunction getPreviousPage<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number | null {\n  return state.query.pagination.page === 0\n    ? null\n    : state.query.pagination.page - 1;\n}\n\nfunction getPages<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number[] {\n  const padding = 4;\n  const min = 0;\n  const max = getPageCount(state) - 1;\n  const desiredStart = state.query.pagination.page - padding;\n  const clampedStart = Math.max(min, desiredStart);\n  const desiredEnd = state.query.pagination.page + padding;\n  const clampedEnd = Math.min(max, desiredEnd);\n  const start = Math.max(min, clampedStart - (desiredEnd - clampedEnd));\n  const end = Math.min(max, clampedEnd + (clampedStart - desiredStart));\n  return range(start, end + 1);\n}\n\nfunction getNextPage<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number | null {\n  const max = getPageCount(state) - 1;\n  const next = state.query.pagination.page + 1;\n  return next <= max ? next : null;\n}\n\n// We don't want to show the pagination controls when they are unnecessary.\nfunction getShowPaginationControls<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): boolean {\n  const smallestPageSize = Math.min(...[...RivTable.pageSizes]);\n  return state.result.totalMatchingRowCount > smallestPageSize;\n}\n\nfunction getAllColumns<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  supportedColumns: Map<C, RivTable.ColumnMetadata>,\n): RivTable.ColumnSettings<C>[] {\n  // If the table offers more columns than the user has configuration settings\n  // for (or if the user has no configuration settings yet), we'll append them\n  // to the end. This ensures that new columns we add to existing tables over\n  // time (1) get displayed even though they don't appear in the user's\n  // configuration settings yet, and (2) don't interrupt their existing setup.\n  const columnNamesWithoutUserSettings = difference(\n    [...supportedColumns.keys()],\n    state.display.columnSettings.map(({ name }) => name),\n  );\n\n  // Throw out settings for columns no longer offered by the table.\n  const columnsWithUserSettings: RivTable.ColumnSettings<C>[] =\n    state.display.columnSettings.filter(({ name }) =>\n      supportedColumns.has(name),\n    );\n\n  const columnsWithoutUserSettings: RivTable.ColumnSettings<C>[] = [\n    ...columnNamesWithoutUserSettings,\n  ].map((name: C) => ({\n    name,\n    enabled: true,\n    preferredWidth: 'auto',\n    pinned: false,\n  }));\n\n  return [...columnsWithUserSettings, ...columnsWithoutUserSettings];\n}\n\nfunction getAlignment(\n  metadata: RivTable.ColumnMetadata,\n  index: number,\n): RivTable.ColumnAlignment {\n  if (index === 0) return 'left';\n  switch (metadata.dataType) {\n    case 'date':\n    case 'longText':\n      return 'left';\n    case 'advanced':\n    case 'icon':\n    case 'shortText':\n      return 'center';\n    case 'currency':\n    case 'number':\n      return 'right';\n  }\n}\n\nfunction resolveColumns<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  supportedColumns: Map<C, RivTable.ColumnMetadata>,\n): RivTable.FullColumn<C>[] {\n  const allColumns = getAllColumns(state, supportedColumns);\n  return allColumns\n    .filter(({ enabled }) => enabled)\n    .reduce(\n      (\n        fullColumns: RivTable.FullColumn<C>[],\n        settings: RivTable.ColumnSettings<C>,\n        i: number,\n      ): RivTable.FullColumn<C>[] => {\n        const metadata = supportedColumns.get(settings.name)!;\n        const resolvedWidth =\n          settings.preferredWidth === 'auto'\n            ? metadata.minWidth\n            : Math.max(metadata.minWidth, settings.preferredWidth);\n        const previousColumn: RivTable.FullColumn<C> | undefined =\n          fullColumns[i - 1];\n        return [\n          ...fullColumns,\n          {\n            ...settings,\n            ...metadata,\n            width: resolvedWidth,\n            left: settings.pinned\n              ? previousColumn\n                ? (previousColumn.left || 0) + previousColumn.width\n                : 0\n              : null,\n            alignment: getAlignment(metadata, i),\n          },\n        ];\n      },\n      [],\n    );\n}\n\nfunction getZeroStateMessage<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>, entity: string): string | null {\n  if (state.result.totalMatchingRowCount > 0) return null;\n  if (state.query.search)\n    return `No ${entity} match your current search keyword.`;\n  if (state.query.filters) return `No ${entity} match your current filters.`;\n  return `No ${entity}.`;\n}\n\nfunction changeColumnPin<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  column: C,\n  pinned: boolean,\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: orderBy(\n        allColumns.map(c => ({\n          ...c,\n          pinned: c.name === column ? pinned : c.pinned,\n        })),\n        v => (v.pinned ? 1 : 0),\n        'desc',\n      ),\n    },\n  };\n}\n\nfunction changeColumnOrder<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  previousIndex: number,\n  newIndex: number,\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n\n  // First, put the columns in the desired order.\n  const item = allColumns[previousIndex];\n  const withoutItem = allColumns.filter((_, i) => i !== previousIndex);\n  const reordered = [\n    ...withoutItem.slice(0, newIndex),\n    item,\n    ...withoutItem.slice(newIndex),\n  ];\n\n  // Then, we may need to fix the pins (all pinned columns appear at the\n  // beginning of the columns array) since the user is allowed to drag\n  // and drop columns to and from the pinned area. If the user drags a\n  // column across that threshold, update its pinned status.\n  const updated = reordered.map((settings, i, arr) => {\n    if (newIndex === i) {\n      return {\n        ...settings,\n        pinned: settings.pinned\n          ? arr[i - 1]?.pinned ?? true\n          : arr[i + 1]?.pinned ?? false,\n      };\n    } else return settings;\n  });\n\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: updated,\n    },\n  };\n}\n\nfunction changeColumnEnabled<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  column: C,\n  enabled: boolean,\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: allColumns.map(c => ({\n        ...c,\n        enabled: c.name === column ? enabled : c.enabled,\n      })),\n    },\n  };\n}\n\nfunction changeColumnWidth<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  column: C,\n  preferredWidth: RivTable.ColumnSettings<C>['preferredWidth'],\n): RivTable.CoreState<R, C, F> {\n  const allColumns = getAllColumns(state, columns);\n  return {\n    ...state,\n    display: {\n      ...state.display,\n      columnSettings: allColumns.map(c => ({\n        ...c,\n        preferredWidth: c.name === column ? preferredWidth : c.preferredWidth,\n      })),\n    },\n  };\n}\n\nfunction isRowSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>, id: R['id']): boolean {\n  switch (state.selection.mode) {\n    case 'include':\n      return state.selection.included.has(id);\n    case 'exclude':\n      return !state.selection.excluded.has(id);\n  }\n}\n\nfunction isAllSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.MultiSelectionState {\n  if (\n    (state.selection.mode === 'exclude' &&\n      state.selection.excluded.size === 0) ||\n    (state.selection.mode === 'include' &&\n      state.selection.included.size === state.result.totalMatchingRowCount)\n  )\n    return true;\n  if (\n    (state.selection.mode === 'exclude' &&\n      state.selection.excluded.size === state.result.totalMatchingRowCount) ||\n    (state.selection.mode === 'include' && state.selection.included.size === 0)\n  )\n    return false;\n  return 'indeterminate';\n}\n\nfunction isCurrentPageSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.MultiSelectionState {\n  const selectedStates = state.result.currentPageData.map(({ id }) =>\n    isRowSelected(state, id),\n  );\n  if (selectedStates.length > 0) {\n    if (selectedStates.every(v => v)) return true;\n    if (selectedStates.some(v => v)) return 'indeterminate';\n  }\n  return false;\n}\n\nfunction selectedCount<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): number {\n  switch (state.selection.mode) {\n    case 'include':\n      return state.selection.included.size;\n    case 'exclude':\n      return state.result.totalMatchingRowCount - state.selection.excluded.size;\n  }\n}\n\nasync function* refreshResultWith<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  source: RivTable.Source<R, C, F>,\n  mostRecentAction: RivTable.Action<R, C, F>,\n): AsyncGenerator<RivTable.CoreState<R, C, F>> {\n  yield {\n    ...state,\n    load: {\n      loading: true,\n      error: null,\n    },\n  };\n  try {\n    const result = await source(state.query, mostRecentAction);\n    yield {\n      ...state,\n      load: {\n        loading: false,\n        error: null,\n      },\n      result,\n    };\n  } catch (error) {\n    yield {\n      ...state,\n      load: {\n        loading: false,\n        error,\n      },\n    };\n  }\n}\n\nfunction setRowSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  id: R['id'],\n  selected: boolean,\n): RivTable.CoreState<R, C, F> {\n  return {\n    ...state,\n    selection:\n      state.selection.mode === 'include'\n        ? {\n            mode: 'include',\n            included: selected\n              ? new Set([...state.selection.included, id])\n              : new Set([...state.selection.included].filter(s => s !== id)),\n          }\n        : {\n            mode: 'exclude',\n            excluded: selected\n              ? new Set([...state.selection.excluded].filter(s => s !== id))\n              : new Set([...state.selection.excluded, id]),\n          },\n  };\n}\n\nfunction togglePageSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.CoreState<R, C, F> {\n  const isPageFullySelected = state.result.currentPageData.every(({ id }) =>\n    isRowSelected(state, id),\n  );\n  return state.result.currentPageData.reduce((accumulatedState, row) => {\n    return setRowSelected(accumulatedState, row.id, !isPageFullySelected);\n  }, state);\n}\n\nfunction toggleAllSelected<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>): RivTable.CoreState<R, C, F> {\n  if (isAllSelected(state) === true) {\n    return {\n      ...state,\n      selection: {\n        mode: 'include',\n        included: new Set(),\n      },\n    };\n  } else {\n    return {\n      ...state,\n      selection: {\n        mode: 'exclude',\n        excluded: new Set(),\n      },\n    };\n  }\n}\n\nfunction toggleColumnOrder<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(state: RivTable.CoreState<R, C, F>, column: C): RivTable.CoreState<R, C, F> {\n  if (state.query.order?.column === column) {\n    return {\n      ...state,\n      query: {\n        ...state.query,\n        order:\n          state.query.order.direction === 'asc'\n            ? {\n                column,\n                direction: 'desc',\n              }\n            : null,\n      },\n    };\n  }\n  return {\n    ...state,\n    query: {\n      ...state.query,\n      order: {\n        column,\n        direction: 'asc',\n      },\n    },\n  };\n}\n\nasync function* reduce<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n>(\n  state: RivTable.CoreState<R, C, F>,\n  action: RivTable.Action<R, C, F>,\n  columns: Map<C, RivTable.ColumnMetadata>,\n  source: RivTable.Source<R, C, F>,\n): AsyncGenerator<RivTable.CoreState<R, C, F>> {\n  switch (action.type) {\n    case 'load':\n      yield* refreshResultWith(state, source, action);\n      break;\n    case 'orderChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            order: action.payload,\n          },\n          selection: {\n            mode: 'include',\n            included: new Set(),\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'orderColumnToggle':\n      yield* refreshResultWith(\n        toggleColumnOrder(state, action.column),\n        source,\n        action,\n      );\n      break;\n    case 'searchChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            search: action.payload,\n          },\n          selection: {\n            mode: 'include',\n            included: new Set(),\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'paginationChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: action.payload,\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'previousPageNavigate':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              page: getPreviousPage(state) ?? 0,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'nextPageNavigate':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              page: getNextPage(state) ?? getPageCount(state) - 1,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'pageChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              page: action.page,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'pageSizeChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            pagination: {\n              ...state.query.pagination,\n              pageSize: action.size,\n              page: 0,\n            },\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'filtersChange':\n      yield* refreshResultWith(\n        {\n          ...state,\n          query: {\n            ...state.query,\n            filters: action.payload,\n          },\n          selection: {\n            mode: 'include',\n            included: new Set(),\n          },\n        },\n        source,\n        action,\n      );\n      break;\n    case 'columnSettingsChange':\n      yield {\n        ...state,\n        display: {\n          ...state.display,\n          columnSettings: action.payload,\n        },\n      };\n      break;\n    case 'columnPinChange':\n      yield changeColumnPin(state, columns, action.column, action.pinned);\n      break;\n    case 'columnOrderChange':\n      yield changeColumnOrder(\n        state,\n        columns,\n        action.previousIndex,\n        action.newIndex,\n      );\n      break;\n    case 'columnEnabledChange':\n      yield changeColumnEnabled(state, columns, action.column, action.enabled);\n      break;\n    case 'columnWidthChange':\n      yield changeColumnWidth(\n        state,\n        columns,\n        action.column,\n        action.preferredWidth,\n      );\n      break;\n    case 'selectionChange':\n      yield {\n        ...state,\n        selection: action.payload,\n      };\n      break;\n    case 'rowSelectedChange':\n      yield setRowSelected(state, action.id, action.selected);\n      break;\n    case 'pageSelectedChange':\n      yield togglePageSelected(state);\n      break;\n    case 'allSelectedChange':\n      yield toggleAllSelected(state);\n      break;\n  }\n}\n"]}
|
|
@@ -82,10 +82,10 @@ export class TableComponent {
|
|
|
82
82
|
}
|
|
83
83
|
}
|
|
84
84
|
TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
-
TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "riv-table", inputs: { manager: "manager" }, queries: [{ propertyName: "cellTemplate", first: true, predicate: ["cell"], descendants: true }, { propertyName: "menuTemplate", first: true, predicate: ["menu"], descendants: true }, { propertyName: "selectionTemplate", first: true, predicate: ["selection"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n <riv-callout\n *riv-callout\n [anchor]=\"position\"\n [isModal]=\"false\"\n [theme]=\"'light'\"\n [showCaret]=\"false\"\n [preferredPosition]=\"'top-right'\"\n >\n <ng-container\n *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n ></ng-container>\n </riv-callout>\n </ng-container>\n </ng-container>\n <riv-loading-cover\n [loading]=\"s.load.loading\"\n [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n >\n <div class=\"container\" (rivClientSize)=\"containerSize.next($event)\">\n <table>\n <thead>\n <tr>\n <th *ngIf=\"selectionTemplate\" class=\"selection-head\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [value]=\"s.selection.isCurrentPageSelected === true\"\n [indeterminate]=\"\n s.selection.isCurrentPageSelected === 'indeterminate'\n \"\n (valueChange)=\"\n manager?.actions?.next({ type: 'pageSelectedChange' })\n \"\n ></riv-checkbox>\n </div>\n </th>\n <th\n *ngFor=\"let column of s.display.columns; let i = index\"\n [class.pinned]=\"column.pinned\"\n [style.left.px]=\"column.left\"\n [style.width.px]=\"getWidth(column)\"\n draggable=\"true\"\n droppable=\"true\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n [class.dragged-over-left]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx > i\n \"\n [class.dragged-over-right]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx < i\n \"\n >\n <div\n *ngIf=\"!column.orderable\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n >\n {{ column.name }}\n </div>\n <button\n *ngIf=\"column.orderable\"\n type=\"button\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n [class.active]=\"s.query.order?.column === column.name\"\n (click)=\"\n manager?.actions?.next({\n type: 'orderColumnToggle',\n column: column.name\n })\n \"\n >\n {{ column.name }}\n <span class=\"icon-container\">\n <riv-icon\n [size]=\"12\"\n [name]=\"\n s.query.order?.column === column.name &&\n s.query.order?.direction === 'desc'\n ? 'ArrowDown'\n : 'ArrowUp'\n \"\n ></riv-icon>\n </span>\n </button>\n <table-header-resize-handle\n (dragResize)=\"setWidth(column.name, $event)\"\n ></table-header-resize-handle>\n </th>\n <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\">\n <ng-container\n *ngFor=\"let row of s.result.rows; trackBy: trackByRow\"\n >\n <ng-template #rowBody>\n <td *ngIf=\"selectionTemplate\" class=\"selection-body\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [identifier]=\"'riv-table-selection-' + row.id\"\n [value]=\"row.selected\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'rowSelectedChange',\n id: row.id,\n selected: $event\n })\n \"\n ></riv-checkbox>\n </div>\n </td>\n <td\n *ngFor=\"let column of s.display.columns\"\n [class.pinned]=\"column.pinned\"\n [class.advanced]=\"column.dataType === 'advanced'\"\n [style.left.px]=\"column.left\"\n [style.text-align]=\"column.alignment\"\n (click)=\"\n column.dataType === 'advanced'\n ? $event.preventDefault()\n : null\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"\n cellTemplate || null;\n context: { row: row, column: column }\n \"\n ></ng-container>\n </td>\n <td\n *ngIf=\"menuTemplate\"\n class=\"menu-body\"\n (click)=\"$event.preventDefault()\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n menuTemplate || null;\n context: { row: row }\n \"\n ></ng-container>\n </td>\n </ng-template>\n <a *ngIf=\"row.rowLink; let href\" [href]=\"href\" class=\"row-link\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </a>\n <tr *ngIf=\"!row.rowLink\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </tr>\n </ng-container>\n </ng-container>\n <ng-template #empty>\n <tr>\n <td [attr.colspan]=\"s.display.columns.length\">\n <riv-zero-state\n *ngIf=\"s.display.zeroStateMessage; let message\"\n [message]=\"message\"\n ></riv-zero-state>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n </div>\n <div class=\"pagination\">\n <div class=\"page-size-controls\">\n Results per page:\n <riv-single-select\n [selectedOption]=\"{\n id: s.query.pagination.pageSize.toString(),\n title: s.query.pagination.pageSize.toString(),\n value: s.query.pagination.pageSize\n }\"\n (selectedOptionChange)=\"\n manager?.actions?.next({\n type: 'pageSizeChange',\n size: $event.value\n })\n \"\n [groups]=\"pageSizeOptions\"\n ></riv-single-select>\n </div>\n <div class=\"pagination-controls\">\n <button\n class=\"paginate previous\"\n type=\"button\"\n [disabled]=\"s.query.pagination.previous === null\"\n (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowLeft'\" [size]=\"16\"></riv-icon>\n </button>\n <span *ngIf=\"s.query.pagination.pages[0] > 0\" class=\"truncated-pages\">\n …\n </span>\n <button\n *ngFor=\"let page of s.query.pagination.pages\"\n class=\"page\"\n type=\"button\"\n [disabled]=\"page === s.query.pagination.page\"\n (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n >\n {{ page + 1 }}\n </button>\n <span\n *ngIf=\"\n s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n s.query.pagination.pageCount - 1\n \"\n class=\"truncated-pages\"\n >\n …\n </span>\n <button\n class=\"paginate next\"\n type=\"button\"\n [disabled]=\"s.query.pagination.next === null\"\n (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowRight'\" [size]=\"16\"></riv-icon>\n </button>\n </div>\n </div>\n </riv-loading-cover>\n</ng-container>\n", styles: [":host{display:flex;min-height:0}riv-loading-cover{width:100%;display:grid;grid-template-rows:1fr auto;gap:var(--size-small)}.container{border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-medium);box-shadow:0 0 calc(var(--base-grid-size) / 4) #0000000a,0 0 calc(var(--base-grid-size) / 2) #0000000f,0 var(--base-grid-size) calc(var(--base-grid-size) * 2) #0000000a;overflow:auto}table{border-collapse:separate;width:100%;table-layout:fixed}thead{position:sticky;top:0;z-index:var(--above-scroll-z-index)}th{border-bottom:var(--border-width) solid var(--border-light);background-color:var(--surface-light-1);position:relative}th:not(:last-child){border-right:var(--border-width) solid var(--border-light)}th.pinned{position:sticky;z-index:1}th.dragged-over-left:before,th.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}th.dragged-over-left:before{left:0}th.dragged-over-right:before{right:0}th.selection-head{width:var(--size-xxlarge);position:sticky;z-index:1;left:0;vertical-align:middle}.checkbox-wrapper{display:flex;justify-content:center;align-items:center}th.menu-head{width:var(--size-xxlarge);position:sticky;z-index:1;right:0}.header-wrapper{font-size:calc(var(--base-grid-size) * 2.75);font-weight:var(--font-weight-heavy);line-height:1;text-transform:uppercase;letter-spacing:calc(var(--base-grid-size) / 4);padding:var(--size-xsmall) var(--size-small);display:inline-flex;align-items:center;justify-content:center;width:100%;height:calc(var(--base-grid-size) * 8);white-space:nowrap}.header-wrapper.left{justify-content:flex-start}.header-wrapper.right{justify-content:flex-end}button.header-wrapper{transition:background-color var(--medium-transition);cursor:pointer}button.header-wrapper:hover{background-color:var(--black-20)}button.header-wrapper .icon-container{overflow:hidden;display:inline-block;width:0;height:1em;opacity:0;padding-left:0;transition:width var(--medium-transition),opacity var(--medium-transition),color var(--medium-transition),padding-left var(--medium-transition)}button.header-wrapper:hover .icon-container,button.header-wrapper.active .icon-container{width:calc(var(--base-grid-size) * 3.5);padding-left:var(--size-xsmall);opacity:1}button.header-wrapper:hover .icon-container{color:var(--type-light-low-contrast)}button.header-wrapper.active .icon-container{color:var(--brand)}a.row-link{display:table-row;text-decoration:none;color:inherit}td{border-bottom:var(--border-width) solid var(--border-light);height:calc(var(--base-grid-size) * 8);padding:var(--size-xxsmall) var(--size-small);font:var(--body-small);vertical-align:middle;text-align:center;background-color:var(--surface-light-0)}td.pinned{position:sticky;z-index:1}td.advanced,td.selection-body,td.menu-body{padding:0;vertical-align:middle}td.menu-body{position:sticky;z-index:1;right:0}.pagination{display:flex;justify-content:space-between}.page-size-controls,.pagination-controls{display:flex;align-items:center}.page-size-controls riv-single-select{margin-left:var(--size-small)}.paginate,.page{cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:var(--size-xlarge);height:var(--size-xlarge);padding:var(--size-xxsmall);font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0)}.paginate{border:var(--border-width) solid var(--border-light-blend);border-radius:var(--border-radius-small);color:var(--brand);&:disabled{color:var(--type-light-disabled)}&.previous{margin-right:var(--size-small)}&.next{margin-left:var(--size-small)}}.page{color:var(--brand);&:disabled{background-color:var(--surface-light-2)}}.truncated-pages{color:var(--type-light-disabled)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.CalloutComponent, selector: "riv-callout", inputs: ["anchor", "isModal", "preferredPosition", "allowedPositions", "fallbackDirection", "showCaret", "theme"], outputs: ["close"] }, { kind: "directive", type: i3.CalloutDirective, selector: "[riv-callout]" }, { kind: "component", type: i4.CheckboxComponent, selector: "riv-checkbox", inputs: ["name", "identifier", "value", "checkboxTooltip", "indeterminate", "disabled", "required"], outputs: ["valueChange"] }, { kind: "component", type: i5.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: i6.LoadingCoverComponent, selector: "riv-loading-cover", inputs: ["loading", "loadingSize", "errorMessage"] }, { kind: "component", type: i7.SingleSelectComponent, selector: "riv-single-select", inputs: ["groups", "selectedOption", "filterabilityOptions", "loading", "locked", "maxCalloutHeight", "noOptionsMessage", "nodeTemplate", "triggerTemplate", "placeholder", "disabled"], outputs: ["filterQueryChange", "selectedOptionChange"] }, { kind: "directive", type: i8.SizeDirective, selector: "[rivClientSize]", outputs: ["rivClientSize"] }, { kind: "component", type: i9.TableHeaderResizeHandleComponent, selector: "table-header-resize-handle", outputs: ["dragResize"] }, { kind: "component", type: i10.ZeroStateComponent, selector: "riv-zero-state", inputs: ["message"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
85
|
+
TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "riv-table", inputs: { manager: "manager" }, queries: [{ propertyName: "cellTemplate", first: true, predicate: ["cell"], descendants: true }, { propertyName: "menuTemplate", first: true, predicate: ["menu"], descendants: true }, { propertyName: "selectionTemplate", first: true, predicate: ["selection"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n <riv-callout\n *riv-callout\n [anchor]=\"position\"\n [isModal]=\"false\"\n [theme]=\"'light'\"\n [showCaret]=\"false\"\n [preferredPosition]=\"'top-right'\"\n >\n <ng-container\n *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n ></ng-container>\n </riv-callout>\n </ng-container>\n </ng-container>\n <riv-loading-cover\n [loading]=\"s.load.loading\"\n [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n >\n <div class=\"container\" (rivClientSize)=\"containerSize.next($event)\">\n <table>\n <thead>\n <tr>\n <th *ngIf=\"selectionTemplate\" class=\"selection-head\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [value]=\"s.selection.isCurrentPageSelected === true\"\n [indeterminate]=\"\n s.selection.isCurrentPageSelected === 'indeterminate'\n \"\n (valueChange)=\"\n manager?.actions?.next({ type: 'pageSelectedChange' })\n \"\n ></riv-checkbox>\n </div>\n </th>\n <th\n *ngFor=\"let column of s.display.columns; let i = index\"\n [class.pinned]=\"column.pinned\"\n [style.left.px]=\"column.left\"\n [style.width.px]=\"getWidth(column)\"\n draggable=\"true\"\n droppable=\"true\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n [class.dragged-over-left]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx > i\n \"\n [class.dragged-over-right]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx < i\n \"\n >\n <div\n *ngIf=\"!column.orderable\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n >\n {{ column.name }}\n </div>\n <button\n *ngIf=\"column.orderable\"\n type=\"button\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n [class.active]=\"s.query.order?.column === column.name\"\n (click)=\"\n manager?.actions?.next({\n type: 'orderColumnToggle',\n column: column.name\n })\n \"\n >\n {{ column.name }}\n <span class=\"icon-container\">\n <riv-icon\n [size]=\"12\"\n [name]=\"\n s.query.order?.column === column.name &&\n s.query.order?.direction === 'desc'\n ? 'ArrowDown'\n : 'ArrowUp'\n \"\n ></riv-icon>\n </span>\n </button>\n <table-header-resize-handle\n (dragResize)=\"setWidth(column.name, $event)\"\n ></table-header-resize-handle>\n </th>\n <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\">\n <ng-container\n *ngFor=\"let row of s.result.rows; trackBy: trackByRow\"\n >\n <ng-template #rowBody>\n <td *ngIf=\"selectionTemplate\" class=\"selection-body\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [identifier]=\"'riv-table-selection-' + row.id\"\n [value]=\"row.selected\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'rowSelectedChange',\n id: row.id,\n selected: $event\n })\n \"\n ></riv-checkbox>\n </div>\n </td>\n <td\n *ngFor=\"let column of s.display.columns\"\n [class.pinned]=\"column.pinned\"\n [class.advanced]=\"column.dataType === 'advanced'\"\n [style.left.px]=\"column.left\"\n [style.text-align]=\"column.alignment\"\n (click)=\"\n column.dataType === 'advanced'\n ? $event.preventDefault()\n : null\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"\n cellTemplate || null;\n context: { row: row, column: column }\n \"\n ></ng-container>\n </td>\n <td\n *ngIf=\"menuTemplate\"\n class=\"menu-body\"\n (click)=\"$event.preventDefault()\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n menuTemplate || null;\n context: { row: row }\n \"\n ></ng-container>\n </td>\n </ng-template>\n <a *ngIf=\"row.rowLink; let href\" [href]=\"href\" class=\"row-link\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </a>\n <tr *ngIf=\"!row.rowLink\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </tr>\n </ng-container>\n </ng-container>\n <ng-template #empty>\n <tr>\n <td [attr.colspan]=\"s.display.columns.length\">\n <riv-zero-state\n *ngIf=\"s.display.zeroStateMessage; let message\"\n [message]=\"message\"\n ></riv-zero-state>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n </div>\n <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination\">\n <div class=\"page-size-controls\">\n Results per page:\n <riv-single-select\n [selectedOption]=\"{\n id: s.query.pagination.pageSize.toString(),\n title: s.query.pagination.pageSize.toString(),\n value: s.query.pagination.pageSize\n }\"\n (selectedOptionChange)=\"\n manager?.actions?.next({\n type: 'pageSizeChange',\n size: $event.value\n })\n \"\n [groups]=\"pageSizeOptions\"\n ></riv-single-select>\n </div>\n <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination-controls\">\n <button\n class=\"paginate previous\"\n type=\"button\"\n [disabled]=\"s.query.pagination.previous === null\"\n (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowLeft'\" [size]=\"16\"></riv-icon>\n </button>\n <span *ngIf=\"s.query.pagination.pages[0] > 0\" class=\"truncated-pages\">\n …\n </span>\n <button\n *ngFor=\"let page of s.query.pagination.pages\"\n class=\"page\"\n type=\"button\"\n [disabled]=\"page === s.query.pagination.page\"\n (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n >\n {{ page + 1 }}\n </button>\n <span\n *ngIf=\"\n s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n s.query.pagination.pageCount - 1\n \"\n class=\"truncated-pages\"\n >\n …\n </span>\n <button\n class=\"paginate next\"\n type=\"button\"\n [disabled]=\"s.query.pagination.next === null\"\n (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowRight'\" [size]=\"16\"></riv-icon>\n </button>\n </div>\n </div>\n </riv-loading-cover>\n</ng-container>\n", styles: [":host{display:flex;min-height:0}riv-loading-cover{width:100%;display:grid;grid-template-rows:1fr auto;gap:var(--size-small)}.container{border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-medium);box-shadow:0 0 calc(var(--base-grid-size) / 4) #0000000a,0 0 calc(var(--base-grid-size) / 2) #0000000f,0 var(--base-grid-size) calc(var(--base-grid-size) * 2) #0000000a;overflow:auto}table{border-collapse:separate;width:100%;table-layout:fixed}thead{position:sticky;top:0;z-index:var(--above-scroll-z-index)}th{border-bottom:var(--border-width) solid var(--border-light);background-color:var(--surface-light-1);position:relative}th:not(:last-child){border-right:var(--border-width) solid var(--border-light)}th.pinned{position:sticky;z-index:1}th.dragged-over-left:before,th.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}th.dragged-over-left:before{left:0}th.dragged-over-right:before{right:0}th.selection-head{width:var(--size-xxlarge);position:sticky;z-index:1;left:0;vertical-align:middle}.checkbox-wrapper{display:flex;justify-content:center;align-items:center}th.menu-head{width:var(--size-xxlarge);position:sticky;z-index:1;right:0}.header-wrapper{font-size:calc(var(--base-grid-size) * 2.75);font-weight:var(--font-weight-heavy);line-height:1;text-transform:uppercase;letter-spacing:calc(var(--base-grid-size) / 4);padding:var(--size-xsmall) var(--size-small);display:inline-flex;align-items:center;justify-content:center;width:100%;height:calc(var(--base-grid-size) * 8);white-space:nowrap}.header-wrapper.left{justify-content:flex-start}.header-wrapper.right{justify-content:flex-end}button.header-wrapper{transition:background-color var(--medium-transition);cursor:pointer}button.header-wrapper:hover{background-color:var(--black-20)}button.header-wrapper .icon-container{overflow:hidden;display:inline-block;width:0;height:1em;opacity:0;padding-left:0;transition:width var(--medium-transition),opacity var(--medium-transition),color var(--medium-transition),padding-left var(--medium-transition)}button.header-wrapper:hover .icon-container,button.header-wrapper.active .icon-container{width:calc(var(--base-grid-size) * 3.5);padding-left:var(--size-xsmall);opacity:1}button.header-wrapper:hover .icon-container{color:var(--type-light-low-contrast)}button.header-wrapper.active .icon-container{color:var(--brand)}a.row-link{display:table-row;text-decoration:none;color:inherit}td{border-bottom:var(--border-width) solid var(--border-light);height:calc(var(--base-grid-size) * 8);padding:var(--size-xxsmall) var(--size-small);font:var(--body-small);vertical-align:middle;text-align:center;background-color:var(--surface-light-0)}td.pinned{position:sticky;z-index:1}td.advanced,td.selection-body,td.menu-body{padding:0;vertical-align:middle}td.menu-body{position:sticky;z-index:1;right:0}.pagination{display:flex;justify-content:space-between}.page-size-controls,.pagination-controls{display:flex;align-items:center}.page-size-controls riv-single-select{margin-left:var(--size-small)}.paginate,.page{cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:var(--size-xlarge);height:var(--size-xlarge);padding:var(--size-xxsmall);font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0)}.paginate{border:var(--border-width) solid var(--border-light-blend);border-radius:var(--border-radius-small);color:var(--brand);&:disabled{color:var(--type-light-disabled)}&.previous{margin-right:var(--size-small)}&.next{margin-left:var(--size-small)}}.page{color:var(--brand);&:disabled{background-color:var(--surface-light-2)}}.truncated-pages{color:var(--type-light-disabled)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.CalloutComponent, selector: "riv-callout", inputs: ["anchor", "isModal", "preferredPosition", "allowedPositions", "fallbackDirection", "showCaret", "theme"], outputs: ["close"] }, { kind: "directive", type: i3.CalloutDirective, selector: "[riv-callout]" }, { kind: "component", type: i4.CheckboxComponent, selector: "riv-checkbox", inputs: ["name", "identifier", "value", "checkboxTooltip", "indeterminate", "disabled", "required"], outputs: ["valueChange"] }, { kind: "component", type: i5.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: i6.LoadingCoverComponent, selector: "riv-loading-cover", inputs: ["loading", "loadingSize", "errorMessage"] }, { kind: "component", type: i7.SingleSelectComponent, selector: "riv-single-select", inputs: ["groups", "selectedOption", "filterabilityOptions", "loading", "locked", "maxCalloutHeight", "noOptionsMessage", "nodeTemplate", "triggerTemplate", "placeholder", "disabled"], outputs: ["filterQueryChange", "selectedOptionChange"] }, { kind: "directive", type: i8.SizeDirective, selector: "[rivClientSize]", outputs: ["rivClientSize"] }, { kind: "component", type: i9.TableHeaderResizeHandleComponent, selector: "table-header-resize-handle", outputs: ["dragResize"] }, { kind: "component", type: i10.ZeroStateComponent, selector: "riv-zero-state", inputs: ["message"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
86
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, decorators: [{
|
|
87
87
|
type: Component,
|
|
88
|
-
args: [{ selector: 'riv-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n <riv-callout\n *riv-callout\n [anchor]=\"position\"\n [isModal]=\"false\"\n [theme]=\"'light'\"\n [showCaret]=\"false\"\n [preferredPosition]=\"'top-right'\"\n >\n <ng-container\n *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n ></ng-container>\n </riv-callout>\n </ng-container>\n </ng-container>\n <riv-loading-cover\n [loading]=\"s.load.loading\"\n [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n >\n <div class=\"container\" (rivClientSize)=\"containerSize.next($event)\">\n <table>\n <thead>\n <tr>\n <th *ngIf=\"selectionTemplate\" class=\"selection-head\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [value]=\"s.selection.isCurrentPageSelected === true\"\n [indeterminate]=\"\n s.selection.isCurrentPageSelected === 'indeterminate'\n \"\n (valueChange)=\"\n manager?.actions?.next({ type: 'pageSelectedChange' })\n \"\n ></riv-checkbox>\n </div>\n </th>\n <th\n *ngFor=\"let column of s.display.columns; let i = index\"\n [class.pinned]=\"column.pinned\"\n [style.left.px]=\"column.left\"\n [style.width.px]=\"getWidth(column)\"\n draggable=\"true\"\n droppable=\"true\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n [class.dragged-over-left]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx > i\n \"\n [class.dragged-over-right]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx < i\n \"\n >\n <div\n *ngIf=\"!column.orderable\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n >\n {{ column.name }}\n </div>\n <button\n *ngIf=\"column.orderable\"\n type=\"button\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n [class.active]=\"s.query.order?.column === column.name\"\n (click)=\"\n manager?.actions?.next({\n type: 'orderColumnToggle',\n column: column.name\n })\n \"\n >\n {{ column.name }}\n <span class=\"icon-container\">\n <riv-icon\n [size]=\"12\"\n [name]=\"\n s.query.order?.column === column.name &&\n s.query.order?.direction === 'desc'\n ? 'ArrowDown'\n : 'ArrowUp'\n \"\n ></riv-icon>\n </span>\n </button>\n <table-header-resize-handle\n (dragResize)=\"setWidth(column.name, $event)\"\n ></table-header-resize-handle>\n </th>\n <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\">\n <ng-container\n *ngFor=\"let row of s.result.rows; trackBy: trackByRow\"\n >\n <ng-template #rowBody>\n <td *ngIf=\"selectionTemplate\" class=\"selection-body\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [identifier]=\"'riv-table-selection-' + row.id\"\n [value]=\"row.selected\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'rowSelectedChange',\n id: row.id,\n selected: $event\n })\n \"\n ></riv-checkbox>\n </div>\n </td>\n <td\n *ngFor=\"let column of s.display.columns\"\n [class.pinned]=\"column.pinned\"\n [class.advanced]=\"column.dataType === 'advanced'\"\n [style.left.px]=\"column.left\"\n [style.text-align]=\"column.alignment\"\n (click)=\"\n column.dataType === 'advanced'\n ? $event.preventDefault()\n : null\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"\n cellTemplate || null;\n context: { row: row, column: column }\n \"\n ></ng-container>\n </td>\n <td\n *ngIf=\"menuTemplate\"\n class=\"menu-body\"\n (click)=\"$event.preventDefault()\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n menuTemplate || null;\n context: { row: row }\n \"\n ></ng-container>\n </td>\n </ng-template>\n <a *ngIf=\"row.rowLink; let href\" [href]=\"href\" class=\"row-link\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </a>\n <tr *ngIf=\"!row.rowLink\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </tr>\n </ng-container>\n </ng-container>\n <ng-template #empty>\n <tr>\n <td [attr.colspan]=\"s.display.columns.length\">\n <riv-zero-state\n *ngIf=\"s.display.zeroStateMessage; let message\"\n [message]=\"message\"\n ></riv-zero-state>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n </div>\n <div class=\"pagination\">\n <div class=\"page-size-controls\">\n Results per page:\n <riv-single-select\n [selectedOption]=\"{\n id: s.query.pagination.pageSize.toString(),\n title: s.query.pagination.pageSize.toString(),\n value: s.query.pagination.pageSize\n }\"\n (selectedOptionChange)=\"\n manager?.actions?.next({\n type: 'pageSizeChange',\n size: $event.value\n })\n \"\n [groups]=\"pageSizeOptions\"\n ></riv-single-select>\n </div>\n <div class=\"pagination-controls\">\n <button\n class=\"paginate previous\"\n type=\"button\"\n [disabled]=\"s.query.pagination.previous === null\"\n (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowLeft'\" [size]=\"16\"></riv-icon>\n </button>\n <span *ngIf=\"s.query.pagination.pages[0] > 0\" class=\"truncated-pages\">\n …\n </span>\n <button\n *ngFor=\"let page of s.query.pagination.pages\"\n class=\"page\"\n type=\"button\"\n [disabled]=\"page === s.query.pagination.page\"\n (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n >\n {{ page + 1 }}\n </button>\n <span\n *ngIf=\"\n s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n s.query.pagination.pageCount - 1\n \"\n class=\"truncated-pages\"\n >\n …\n </span>\n <button\n class=\"paginate next\"\n type=\"button\"\n [disabled]=\"s.query.pagination.next === null\"\n (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowRight'\" [size]=\"16\"></riv-icon>\n </button>\n </div>\n </div>\n </riv-loading-cover>\n</ng-container>\n", styles: [":host{display:flex;min-height:0}riv-loading-cover{width:100%;display:grid;grid-template-rows:1fr auto;gap:var(--size-small)}.container{border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-medium);box-shadow:0 0 calc(var(--base-grid-size) / 4) #0000000a,0 0 calc(var(--base-grid-size) / 2) #0000000f,0 var(--base-grid-size) calc(var(--base-grid-size) * 2) #0000000a;overflow:auto}table{border-collapse:separate;width:100%;table-layout:fixed}thead{position:sticky;top:0;z-index:var(--above-scroll-z-index)}th{border-bottom:var(--border-width) solid var(--border-light);background-color:var(--surface-light-1);position:relative}th:not(:last-child){border-right:var(--border-width) solid var(--border-light)}th.pinned{position:sticky;z-index:1}th.dragged-over-left:before,th.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}th.dragged-over-left:before{left:0}th.dragged-over-right:before{right:0}th.selection-head{width:var(--size-xxlarge);position:sticky;z-index:1;left:0;vertical-align:middle}.checkbox-wrapper{display:flex;justify-content:center;align-items:center}th.menu-head{width:var(--size-xxlarge);position:sticky;z-index:1;right:0}.header-wrapper{font-size:calc(var(--base-grid-size) * 2.75);font-weight:var(--font-weight-heavy);line-height:1;text-transform:uppercase;letter-spacing:calc(var(--base-grid-size) / 4);padding:var(--size-xsmall) var(--size-small);display:inline-flex;align-items:center;justify-content:center;width:100%;height:calc(var(--base-grid-size) * 8);white-space:nowrap}.header-wrapper.left{justify-content:flex-start}.header-wrapper.right{justify-content:flex-end}button.header-wrapper{transition:background-color var(--medium-transition);cursor:pointer}button.header-wrapper:hover{background-color:var(--black-20)}button.header-wrapper .icon-container{overflow:hidden;display:inline-block;width:0;height:1em;opacity:0;padding-left:0;transition:width var(--medium-transition),opacity var(--medium-transition),color var(--medium-transition),padding-left var(--medium-transition)}button.header-wrapper:hover .icon-container,button.header-wrapper.active .icon-container{width:calc(var(--base-grid-size) * 3.5);padding-left:var(--size-xsmall);opacity:1}button.header-wrapper:hover .icon-container{color:var(--type-light-low-contrast)}button.header-wrapper.active .icon-container{color:var(--brand)}a.row-link{display:table-row;text-decoration:none;color:inherit}td{border-bottom:var(--border-width) solid var(--border-light);height:calc(var(--base-grid-size) * 8);padding:var(--size-xxsmall) var(--size-small);font:var(--body-small);vertical-align:middle;text-align:center;background-color:var(--surface-light-0)}td.pinned{position:sticky;z-index:1}td.advanced,td.selection-body,td.menu-body{padding:0;vertical-align:middle}td.menu-body{position:sticky;z-index:1;right:0}.pagination{display:flex;justify-content:space-between}.page-size-controls,.pagination-controls{display:flex;align-items:center}.page-size-controls riv-single-select{margin-left:var(--size-small)}.paginate,.page{cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:var(--size-xlarge);height:var(--size-xlarge);padding:var(--size-xxsmall);font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0)}.paginate{border:var(--border-width) solid var(--border-light-blend);border-radius:var(--border-radius-small);color:var(--brand);&:disabled{color:var(--type-light-disabled)}&.previous{margin-right:var(--size-small)}&.next{margin-left:var(--size-small)}}.page{color:var(--brand);&:disabled{background-color:var(--surface-light-2)}}.truncated-pages{color:var(--type-light-disabled)}\n"] }]
|
|
88
|
+
args: [{ selector: 'riv-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n <riv-callout\n *riv-callout\n [anchor]=\"position\"\n [isModal]=\"false\"\n [theme]=\"'light'\"\n [showCaret]=\"false\"\n [preferredPosition]=\"'top-right'\"\n >\n <ng-container\n *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n ></ng-container>\n </riv-callout>\n </ng-container>\n </ng-container>\n <riv-loading-cover\n [loading]=\"s.load.loading\"\n [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n >\n <div class=\"container\" (rivClientSize)=\"containerSize.next($event)\">\n <table>\n <thead>\n <tr>\n <th *ngIf=\"selectionTemplate\" class=\"selection-head\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [value]=\"s.selection.isCurrentPageSelected === true\"\n [indeterminate]=\"\n s.selection.isCurrentPageSelected === 'indeterminate'\n \"\n (valueChange)=\"\n manager?.actions?.next({ type: 'pageSelectedChange' })\n \"\n ></riv-checkbox>\n </div>\n </th>\n <th\n *ngFor=\"let column of s.display.columns; let i = index\"\n [class.pinned]=\"column.pinned\"\n [style.left.px]=\"column.left\"\n [style.width.px]=\"getWidth(column)\"\n draggable=\"true\"\n droppable=\"true\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n [class.dragged-over-left]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx > i\n \"\n [class.dragged-over-right]=\"\n draggedOverColumnIdx === i &&\n draggedColumnIdx !== null &&\n draggedColumnIdx < i\n \"\n >\n <div\n *ngIf=\"!column.orderable\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n >\n {{ column.name }}\n </div>\n <button\n *ngIf=\"column.orderable\"\n type=\"button\"\n class=\"header-wrapper\"\n [class.left]=\"column.alignment === 'left'\"\n [class.right]=\"column.alignment === 'right'\"\n [class.active]=\"s.query.order?.column === column.name\"\n (click)=\"\n manager?.actions?.next({\n type: 'orderColumnToggle',\n column: column.name\n })\n \"\n >\n {{ column.name }}\n <span class=\"icon-container\">\n <riv-icon\n [size]=\"12\"\n [name]=\"\n s.query.order?.column === column.name &&\n s.query.order?.direction === 'desc'\n ? 'ArrowDown'\n : 'ArrowUp'\n \"\n ></riv-icon>\n </span>\n </button>\n <table-header-resize-handle\n (dragResize)=\"setWidth(column.name, $event)\"\n ></table-header-resize-handle>\n </th>\n <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\">\n <ng-container\n *ngFor=\"let row of s.result.rows; trackBy: trackByRow\"\n >\n <ng-template #rowBody>\n <td *ngIf=\"selectionTemplate\" class=\"selection-body\">\n <div class=\"checkbox-wrapper\">\n <riv-checkbox\n [identifier]=\"'riv-table-selection-' + row.id\"\n [value]=\"row.selected\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'rowSelectedChange',\n id: row.id,\n selected: $event\n })\n \"\n ></riv-checkbox>\n </div>\n </td>\n <td\n *ngFor=\"let column of s.display.columns\"\n [class.pinned]=\"column.pinned\"\n [class.advanced]=\"column.dataType === 'advanced'\"\n [style.left.px]=\"column.left\"\n [style.text-align]=\"column.alignment\"\n (click)=\"\n column.dataType === 'advanced'\n ? $event.preventDefault()\n : null\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"\n cellTemplate || null;\n context: { row: row, column: column }\n \"\n ></ng-container>\n </td>\n <td\n *ngIf=\"menuTemplate\"\n class=\"menu-body\"\n (click)=\"$event.preventDefault()\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n menuTemplate || null;\n context: { row: row }\n \"\n ></ng-container>\n </td>\n </ng-template>\n <a *ngIf=\"row.rowLink; let href\" [href]=\"href\" class=\"row-link\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </a>\n <tr *ngIf=\"!row.rowLink\">\n <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n </tr>\n </ng-container>\n </ng-container>\n <ng-template #empty>\n <tr>\n <td [attr.colspan]=\"s.display.columns.length\">\n <riv-zero-state\n *ngIf=\"s.display.zeroStateMessage; let message\"\n [message]=\"message\"\n ></riv-zero-state>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n </div>\n <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination\">\n <div class=\"page-size-controls\">\n Results per page:\n <riv-single-select\n [selectedOption]=\"{\n id: s.query.pagination.pageSize.toString(),\n title: s.query.pagination.pageSize.toString(),\n value: s.query.pagination.pageSize\n }\"\n (selectedOptionChange)=\"\n manager?.actions?.next({\n type: 'pageSizeChange',\n size: $event.value\n })\n \"\n [groups]=\"pageSizeOptions\"\n ></riv-single-select>\n </div>\n <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination-controls\">\n <button\n class=\"paginate previous\"\n type=\"button\"\n [disabled]=\"s.query.pagination.previous === null\"\n (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowLeft'\" [size]=\"16\"></riv-icon>\n </button>\n <span *ngIf=\"s.query.pagination.pages[0] > 0\" class=\"truncated-pages\">\n …\n </span>\n <button\n *ngFor=\"let page of s.query.pagination.pages\"\n class=\"page\"\n type=\"button\"\n [disabled]=\"page === s.query.pagination.page\"\n (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n >\n {{ page + 1 }}\n </button>\n <span\n *ngIf=\"\n s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n s.query.pagination.pageCount - 1\n \"\n class=\"truncated-pages\"\n >\n …\n </span>\n <button\n class=\"paginate next\"\n type=\"button\"\n [disabled]=\"s.query.pagination.next === null\"\n (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n >\n <riv-icon [name]=\"'ArrowRight'\" [size]=\"16\"></riv-icon>\n </button>\n </div>\n </div>\n </riv-loading-cover>\n</ng-container>\n", styles: [":host{display:flex;min-height:0}riv-loading-cover{width:100%;display:grid;grid-template-rows:1fr auto;gap:var(--size-small)}.container{border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-medium);box-shadow:0 0 calc(var(--base-grid-size) / 4) #0000000a,0 0 calc(var(--base-grid-size) / 2) #0000000f,0 var(--base-grid-size) calc(var(--base-grid-size) * 2) #0000000a;overflow:auto}table{border-collapse:separate;width:100%;table-layout:fixed}thead{position:sticky;top:0;z-index:var(--above-scroll-z-index)}th{border-bottom:var(--border-width) solid var(--border-light);background-color:var(--surface-light-1);position:relative}th:not(:last-child){border-right:var(--border-width) solid var(--border-light)}th.pinned{position:sticky;z-index:1}th.dragged-over-left:before,th.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}th.dragged-over-left:before{left:0}th.dragged-over-right:before{right:0}th.selection-head{width:var(--size-xxlarge);position:sticky;z-index:1;left:0;vertical-align:middle}.checkbox-wrapper{display:flex;justify-content:center;align-items:center}th.menu-head{width:var(--size-xxlarge);position:sticky;z-index:1;right:0}.header-wrapper{font-size:calc(var(--base-grid-size) * 2.75);font-weight:var(--font-weight-heavy);line-height:1;text-transform:uppercase;letter-spacing:calc(var(--base-grid-size) / 4);padding:var(--size-xsmall) var(--size-small);display:inline-flex;align-items:center;justify-content:center;width:100%;height:calc(var(--base-grid-size) * 8);white-space:nowrap}.header-wrapper.left{justify-content:flex-start}.header-wrapper.right{justify-content:flex-end}button.header-wrapper{transition:background-color var(--medium-transition);cursor:pointer}button.header-wrapper:hover{background-color:var(--black-20)}button.header-wrapper .icon-container{overflow:hidden;display:inline-block;width:0;height:1em;opacity:0;padding-left:0;transition:width var(--medium-transition),opacity var(--medium-transition),color var(--medium-transition),padding-left var(--medium-transition)}button.header-wrapper:hover .icon-container,button.header-wrapper.active .icon-container{width:calc(var(--base-grid-size) * 3.5);padding-left:var(--size-xsmall);opacity:1}button.header-wrapper:hover .icon-container{color:var(--type-light-low-contrast)}button.header-wrapper.active .icon-container{color:var(--brand)}a.row-link{display:table-row;text-decoration:none;color:inherit}td{border-bottom:var(--border-width) solid var(--border-light);height:calc(var(--base-grid-size) * 8);padding:var(--size-xxsmall) var(--size-small);font:var(--body-small);vertical-align:middle;text-align:center;background-color:var(--surface-light-0)}td.pinned{position:sticky;z-index:1}td.advanced,td.selection-body,td.menu-body{padding:0;vertical-align:middle}td.menu-body{position:sticky;z-index:1;right:0}.pagination{display:flex;justify-content:space-between}.page-size-controls,.pagination-controls{display:flex;align-items:center}.page-size-controls riv-single-select{margin-left:var(--size-small)}.paginate,.page{cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:var(--size-xlarge);height:var(--size-xlarge);padding:var(--size-xxsmall);font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0)}.paginate{border:var(--border-width) solid var(--border-light-blend);border-radius:var(--border-radius-small);color:var(--brand);&:disabled{color:var(--type-light-disabled)}&.previous{margin-right:var(--size-small)}&.next{margin-left:var(--size-small)}}.page{color:var(--brand);&:disabled{background-color:var(--surface-light-2)}}.truncated-pages{color:var(--type-light-disabled)}\n"] }]
|
|
89
89
|
}], propDecorators: { manager: [{
|
|
90
90
|
type: Input
|
|
91
91
|
}], cellTemplate: [{
|
|
@@ -98,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
98
98
|
type: ContentChild,
|
|
99
99
|
args: ['selection']
|
|
100
100
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/table/table/table.component.ts","../../../../../../projects/riv/src/lib/table/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,GAGN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,GAAG,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAEhD,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;;;;;;;;;;;;AAcpC,MAAM,OAAO,cAAc;IAN3B;QA0BW,kBAAa,GAAG,IAAI,OAAO,EAAW,CAAC;QACvC,6BAAwB,GAC/B,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CACzD,CAAC;QAEK,oBAAe,GACtB;YACE;gBACE,OAAO,EAAE,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;oBAC3C,EAAE,EAAE,QAAQ,CAAC,QAAQ,EAAE;oBACvB,KAAK,EAAE,QAAQ,CAAC,QAAQ,EAAE;oBAC1B,KAAK,EAAE,QAAQ;iBAChB,CAAC,CAAC;aACJ;SACF,CAAC;QAEK,eAAU,GAAyC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CACrE,GAAG,CAAC,EAAE,CAAC;QAEQ,oBAAe,GAAmB,IAAI,GAAG,EAAE,CAAC;QAwB7D,qBAAgB,GAAkB,IAAI,CAAC;QACvC,yBAAoB,GAAkB,IAAI,CAAC;KA2B5C;IAnDC,QAAQ,CAAC,MAAS,EAAE,KAAoB;QACtC,IAAI,KAAK,KAAK,IAAI,EAAE;YAClB,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACxD,IAAI,cAAc,EAAE;gBAClB,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC;oBACzB,IAAI,EAAE,mBAAmB;oBACzB,MAAM;oBACN,cAAc,EAAE,cAAc;iBAC/B,CAAC,CAAC;aACJ;YACD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;SACrC;aAAM;YACL,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;SACzC;IACH,CAAC;IACD,QAAQ,CAAC,MAA8B;QACrC,IAAI,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;YACzC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAE,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;SAC1E;aAAM;YACL,OAAO,MAAM,CAAC,KAAK,CAAC;SACrB;IACH,CAAC;IAKD,SAAS,CAAC,GAAW;QACnB,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC;IAC9B,CAAC;IAED,QAAQ,CAAC,OAAe;QACtB,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC;IACtC,CAAC;IAED,IAAI,CAAC,OAAe;QAClB,IAAI,IAAI,CAAC,gBAAgB,KAAK,IAAI,EAAE;YAClC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC;gBACzB,IAAI,EAAE,mBAAmB;gBACzB,aAAa,EAAE,IAAI,CAAC,gBAAgB;gBACpC,QAAQ,EAAE,OAAO;aAClB,CAAC,CAAC;YACH,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;SAClC;IACH,CAAC;IAED,eAAe,CAAC,CAAU;QACxB,IAAI,CAAC,YAAY,KAAK;YAAE,OAAO,CAAC,CAAC,OAAO,CAAC;QACzC,IAAI,OAAO,CAAC,KAAK,QAAQ;YAAE,OAAO,CAAC,CAAC;QACpC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC;;YACxD,OAAO,oBAAoB,CAAC;IACnC,CAAC;;2GA3FU,cAAc;+FAAd,cAAc,2WCxB3B,iwRA4OA;2FDpNa,cAAc;kBAN1B,SAAS;+BACE,WAAW,mBAGJ,uBAAuB,CAAC,MAAM;8BAQ/C,OAAO;sBADN,KAAK;gBAIN,YAAY;sBADX,YAAY;uBAAC,MAAM;gBAOpB,YAAY;sBADX,YAAY;uBAAC,MAAM;gBAIpB,iBAAiB;sBADhB,YAAY;uBAAC,WAAW","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Input,\n  TemplateRef,\n  TrackByFunction,\n} from '@angular/core';\nimport { map, Observable, Subject } from 'rxjs';\nimport { SingleSelectComponent } from '../../input/single-select/single-select.component';\nimport { RivTable } from '../state';\n\ntype PageSizeOption = {\n  id: string;\n  title: string;\n  value: number;\n};\n\n@Component({\n  selector: 'riv-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableComponent<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n> {\n  @Input()\n  manager?: RivTable.Manager<R, C, F>;\n\n  @ContentChild('cell')\n  cellTemplate?: TemplateRef<{\n    row: RivTable.FullRow<R>;\n    column: RivTable.FullColumn<C>;\n  }>;\n\n  @ContentChild('menu')\n  menuTemplate?: TemplateRef<{ row: RivTable.FullRow<R> }>;\n\n  @ContentChild('selection')\n  selectionTemplate?: TemplateRef<{ state: RivTable.FullState<R, C, F> }>;\n\n  readonly containerSize = new Subject<DOMRect>();\n  readonly selectionCalloutPosition: Observable<DOMRect> =\n    this.containerSize.pipe(\n      map(rect => new DOMRect(rect.x + 44, rect.y - 12, 0, 0)),\n    );\n\n  readonly pageSizeOptions: SingleSelectComponent.OptionGroup<PageSizeOption>[] =\n    [\n      {\n        options: RivTable.pageSizes.map(pageSize => ({\n          id: pageSize.toString(),\n          title: pageSize.toString(),\n          value: pageSize,\n        })),\n      },\n    ];\n\n  readonly trackByRow: TrackByFunction<RivTable.FullRow<R>> = (_, row) =>\n    row.id;\n\n  private readonly temporaryWidths: Map<C, number> = new Map();\n  setWidth(column: C, width: number | null): void {\n    if (width === null) {\n      const temporaryWidth = this.temporaryWidths.get(column);\n      if (temporaryWidth) {\n        this.manager?.actions.next({\n          type: 'columnWidthChange',\n          column,\n          preferredWidth: temporaryWidth,\n        });\n      }\n      this.temporaryWidths.delete(column);\n    } else {\n      this.temporaryWidths.set(column, width);\n    }\n  }\n  getWidth(column: RivTable.FullColumn<C>): number {\n    if (this.temporaryWidths.has(column.name)) {\n      return Math.max(this.temporaryWidths.get(column.name)!, column.minWidth);\n    } else {\n      return column.width;\n    }\n  }\n\n  draggedColumnIdx: number | null = null;\n  draggedOverColumnIdx: number | null = null;\n\n  dragStart(idx: number) {\n    this.draggedColumnIdx = idx;\n  }\n\n  dragOver(ontoIdx: number) {\n    this.draggedOverColumnIdx = ontoIdx;\n  }\n\n  drop(ontoIdx: number) {\n    if (this.draggedColumnIdx !== null) {\n      this.manager?.actions.next({\n        type: 'columnOrderChange',\n        previousIndex: this.draggedColumnIdx,\n        newIndex: ontoIdx,\n      });\n      this.draggedOverColumnIdx = null;\n    }\n  }\n\n  getErrorMessage(e: unknown): string {\n    if (e instanceof Error) return e.message;\n    if (typeof e === 'string') return e;\n    if (typeof e === 'object' && e !== null) return e.toString();\n    else return 'An error occurred.';\n  }\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n    <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n      <riv-callout\n        *riv-callout\n        [anchor]=\"position\"\n        [isModal]=\"false\"\n        [theme]=\"'light'\"\n        [showCaret]=\"false\"\n        [preferredPosition]=\"'top-right'\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n        ></ng-container>\n      </riv-callout>\n    </ng-container>\n  </ng-container>\n  <riv-loading-cover\n    [loading]=\"s.load.loading\"\n    [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n  >\n    <div class=\"container\" (rivClientSize)=\"containerSize.next($event)\">\n      <table>\n        <thead>\n          <tr>\n            <th *ngIf=\"selectionTemplate\" class=\"selection-head\">\n              <div class=\"checkbox-wrapper\">\n                <riv-checkbox\n                  [value]=\"s.selection.isCurrentPageSelected === true\"\n                  [indeterminate]=\"\n                    s.selection.isCurrentPageSelected === 'indeterminate'\n                  \"\n                  (valueChange)=\"\n                    manager?.actions?.next({ type: 'pageSelectedChange' })\n                  \"\n                ></riv-checkbox>\n              </div>\n            </th>\n            <th\n              *ngFor=\"let column of s.display.columns; let i = index\"\n              [class.pinned]=\"column.pinned\"\n              [style.left.px]=\"column.left\"\n              [style.width.px]=\"getWidth(column)\"\n              draggable=\"true\"\n              droppable=\"true\"\n              (dragstart)=\"dragStart(i)\"\n              (dragenter)=\"$event.preventDefault()\"\n              (dragover)=\"$event.preventDefault(); dragOver(i)\"\n              (drop)=\"drop(i)\"\n              [class.dragged-over-left]=\"\n                draggedOverColumnIdx === i &&\n                draggedColumnIdx !== null &&\n                draggedColumnIdx > i\n              \"\n              [class.dragged-over-right]=\"\n                draggedOverColumnIdx === i &&\n                draggedColumnIdx !== null &&\n                draggedColumnIdx < i\n              \"\n            >\n              <div\n                *ngIf=\"!column.orderable\"\n                class=\"header-wrapper\"\n                [class.left]=\"column.alignment === 'left'\"\n                [class.right]=\"column.alignment === 'right'\"\n              >\n                {{ column.name }}\n              </div>\n              <button\n                *ngIf=\"column.orderable\"\n                type=\"button\"\n                class=\"header-wrapper\"\n                [class.left]=\"column.alignment === 'left'\"\n                [class.right]=\"column.alignment === 'right'\"\n                [class.active]=\"s.query.order?.column === column.name\"\n                (click)=\"\n                  manager?.actions?.next({\n                    type: 'orderColumnToggle',\n                    column: column.name\n                  })\n                \"\n              >\n                {{ column.name }}\n                <span class=\"icon-container\">\n                  <riv-icon\n                    [size]=\"12\"\n                    [name]=\"\n                      s.query.order?.column === column.name &&\n                      s.query.order?.direction === 'desc'\n                        ? 'ArrowDown'\n                        : 'ArrowUp'\n                    \"\n                  ></riv-icon>\n                </span>\n              </button>\n              <table-header-resize-handle\n                (dragResize)=\"setWidth(column.name, $event)\"\n              ></table-header-resize-handle>\n            </th>\n            <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n          </tr>\n        </thead>\n        <tbody>\n          <ng-container *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\">\n            <ng-container\n              *ngFor=\"let row of s.result.rows; trackBy: trackByRow\"\n            >\n              <ng-template #rowBody>\n                <td *ngIf=\"selectionTemplate\" class=\"selection-body\">\n                  <div class=\"checkbox-wrapper\">\n                    <riv-checkbox\n                      [identifier]=\"'riv-table-selection-' + row.id\"\n                      [value]=\"row.selected\"\n                      (valueChange)=\"\n                        manager?.actions?.next({\n                          type: 'rowSelectedChange',\n                          id: row.id,\n                          selected: $event\n                        })\n                      \"\n                    ></riv-checkbox>\n                  </div>\n                </td>\n                <td\n                  *ngFor=\"let column of s.display.columns\"\n                  [class.pinned]=\"column.pinned\"\n                  [class.advanced]=\"column.dataType === 'advanced'\"\n                  [style.left.px]=\"column.left\"\n                  [style.text-align]=\"column.alignment\"\n                  (click)=\"\n                    column.dataType === 'advanced'\n                      ? $event.preventDefault()\n                      : null\n                  \"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"\n                      cellTemplate || null;\n                      context: { row: row, column: column }\n                    \"\n                  ></ng-container>\n                </td>\n                <td\n                  *ngIf=\"menuTemplate\"\n                  class=\"menu-body\"\n                  (click)=\"$event.preventDefault()\"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"\n                      menuTemplate || null;\n                      context: { row: row }\n                    \"\n                  ></ng-container>\n                </td>\n              </ng-template>\n              <a *ngIf=\"row.rowLink; let href\" [href]=\"href\" class=\"row-link\">\n                <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n              </a>\n              <tr *ngIf=\"!row.rowLink\">\n                <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n              </tr>\n            </ng-container>\n          </ng-container>\n          <ng-template #empty>\n            <tr>\n              <td [attr.colspan]=\"s.display.columns.length\">\n                <riv-zero-state\n                  *ngIf=\"s.display.zeroStateMessage; let message\"\n                  [message]=\"message\"\n                ></riv-zero-state>\n              </td>\n            </tr>\n          </ng-template>\n        </tbody>\n      </table>\n    </div>\n    <div class=\"pagination\">\n      <div class=\"page-size-controls\">\n        Results per page:\n        <riv-single-select\n          [selectedOption]=\"{\n            id: s.query.pagination.pageSize.toString(),\n            title: s.query.pagination.pageSize.toString(),\n            value: s.query.pagination.pageSize\n          }\"\n          (selectedOptionChange)=\"\n            manager?.actions?.next({\n              type: 'pageSizeChange',\n              size: $event.value\n            })\n          \"\n          [groups]=\"pageSizeOptions\"\n        ></riv-single-select>\n      </div>\n      <div class=\"pagination-controls\">\n        <button\n          class=\"paginate previous\"\n          type=\"button\"\n          [disabled]=\"s.query.pagination.previous === null\"\n          (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n        >\n          <riv-icon [name]=\"'ArrowLeft'\" [size]=\"16\"></riv-icon>\n        </button>\n        <span *ngIf=\"s.query.pagination.pages[0] > 0\" class=\"truncated-pages\">\n          &hellip;\n        </span>\n        <button\n          *ngFor=\"let page of s.query.pagination.pages\"\n          class=\"page\"\n          type=\"button\"\n          [disabled]=\"page === s.query.pagination.page\"\n          (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n        >\n          {{ page + 1 }}\n        </button>\n        <span\n          *ngIf=\"\n            s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n            s.query.pagination.pageCount - 1\n          \"\n          class=\"truncated-pages\"\n        >\n          &hellip;\n        </span>\n        <button\n          class=\"paginate next\"\n          type=\"button\"\n          [disabled]=\"s.query.pagination.next === null\"\n          (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n        >\n          <riv-icon [name]=\"'ArrowRight'\" [size]=\"16\"></riv-icon>\n        </button>\n      </div>\n    </div>\n  </riv-loading-cover>\n</ng-container>\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/table/table/table.component.ts","../../../../../../projects/riv/src/lib/table/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Input,\n  TemplateRef,\n  TrackByFunction,\n} from '@angular/core';\nimport { map, Observable, Subject } from 'rxjs';\nimport { SingleSelectComponent } from '../../input/single-select/single-select.component';\nimport { RivTable } from '../state';\n\ntype PageSizeOption = {\n  id: string;\n  title: string;\n  value: number;\n};\n\n@Component({\n  selector: 'riv-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableComponent<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n> {\n  @Input()\n  manager?: RivTable.Manager<R, C, F>;\n\n  @ContentChild('cell')\n  cellTemplate?: TemplateRef<{\n    row: RivTable.FullRow<R>;\n    column: RivTable.FullColumn<C>;\n  }>;\n\n  @ContentChild('menu')\n  menuTemplate?: TemplateRef<{ row: RivTable.FullRow<R> }>;\n\n  @ContentChild('selection')\n  selectionTemplate?: TemplateRef<{ state: RivTable.FullState<R, C, F> }>;\n\n  readonly containerSize = new Subject<DOMRect>();\n  readonly selectionCalloutPosition: Observable<DOMRect> =\n    this.containerSize.pipe(\n      map(rect => new DOMRect(rect.x + 44, rect.y - 12, 0, 0)),\n    );\n\n  readonly pageSizeOptions: SingleSelectComponent.OptionGroup<PageSizeOption>[] =\n    [\n      {\n        options: RivTable.pageSizes.map(pageSize => ({\n          id: pageSize.toString(),\n          title: pageSize.toString(),\n          value: pageSize,\n        })),\n      },\n    ];\n\n  readonly trackByRow: TrackByFunction<RivTable.FullRow<R>> = (_, row) =>\n    row.id;\n\n  private readonly temporaryWidths: Map<C, number> = new Map();\n  setWidth(column: C, width: number | null): void {\n    if (width === null) {\n      const temporaryWidth = this.temporaryWidths.get(column);\n      if (temporaryWidth) {\n        this.manager?.actions.next({\n          type: 'columnWidthChange',\n          column,\n          preferredWidth: temporaryWidth,\n        });\n      }\n      this.temporaryWidths.delete(column);\n    } else {\n      this.temporaryWidths.set(column, width);\n    }\n  }\n  getWidth(column: RivTable.FullColumn<C>): number {\n    if (this.temporaryWidths.has(column.name)) {\n      return Math.max(this.temporaryWidths.get(column.name)!, column.minWidth);\n    } else {\n      return column.width;\n    }\n  }\n\n  draggedColumnIdx: number | null = null;\n  draggedOverColumnIdx: number | null = null;\n\n  dragStart(idx: number) {\n    this.draggedColumnIdx = idx;\n  }\n\n  dragOver(ontoIdx: number) {\n    this.draggedOverColumnIdx = ontoIdx;\n  }\n\n  drop(ontoIdx: number) {\n    if (this.draggedColumnIdx !== null) {\n      this.manager?.actions.next({\n        type: 'columnOrderChange',\n        previousIndex: this.draggedColumnIdx,\n        newIndex: ontoIdx,\n      });\n      this.draggedOverColumnIdx = null;\n    }\n  }\n\n  getErrorMessage(e: unknown): string {\n    if (e instanceof Error) return e.message;\n    if (typeof e === 'string') return e;\n    if (typeof e === 'object' && e !== null) return e.toString();\n    else return 'An error occurred.';\n  }\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n    <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n      <riv-callout\n        *riv-callout\n        [anchor]=\"position\"\n        [isModal]=\"false\"\n        [theme]=\"'light'\"\n        [showCaret]=\"false\"\n        [preferredPosition]=\"'top-right'\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n        ></ng-container>\n      </riv-callout>\n    </ng-container>\n  </ng-container>\n  <riv-loading-cover\n    [loading]=\"s.load.loading\"\n    [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n  >\n    <div class=\"container\" (rivClientSize)=\"containerSize.next($event)\">\n      <table>\n        <thead>\n          <tr>\n            <th *ngIf=\"selectionTemplate\" class=\"selection-head\">\n              <div class=\"checkbox-wrapper\">\n                <riv-checkbox\n                  [value]=\"s.selection.isCurrentPageSelected === true\"\n                  [indeterminate]=\"\n                    s.selection.isCurrentPageSelected === 'indeterminate'\n                  \"\n                  (valueChange)=\"\n                    manager?.actions?.next({ type: 'pageSelectedChange' })\n                  \"\n                ></riv-checkbox>\n              </div>\n            </th>\n            <th\n              *ngFor=\"let column of s.display.columns; let i = index\"\n              [class.pinned]=\"column.pinned\"\n              [style.left.px]=\"column.left\"\n              [style.width.px]=\"getWidth(column)\"\n              draggable=\"true\"\n              droppable=\"true\"\n              (dragstart)=\"dragStart(i)\"\n              (dragenter)=\"$event.preventDefault()\"\n              (dragover)=\"$event.preventDefault(); dragOver(i)\"\n              (drop)=\"drop(i)\"\n              [class.dragged-over-left]=\"\n                draggedOverColumnIdx === i &&\n                draggedColumnIdx !== null &&\n                draggedColumnIdx > i\n              \"\n              [class.dragged-over-right]=\"\n                draggedOverColumnIdx === i &&\n                draggedColumnIdx !== null &&\n                draggedColumnIdx < i\n              \"\n            >\n              <div\n                *ngIf=\"!column.orderable\"\n                class=\"header-wrapper\"\n                [class.left]=\"column.alignment === 'left'\"\n                [class.right]=\"column.alignment === 'right'\"\n              >\n                {{ column.name }}\n              </div>\n              <button\n                *ngIf=\"column.orderable\"\n                type=\"button\"\n                class=\"header-wrapper\"\n                [class.left]=\"column.alignment === 'left'\"\n                [class.right]=\"column.alignment === 'right'\"\n                [class.active]=\"s.query.order?.column === column.name\"\n                (click)=\"\n                  manager?.actions?.next({\n                    type: 'orderColumnToggle',\n                    column: column.name\n                  })\n                \"\n              >\n                {{ column.name }}\n                <span class=\"icon-container\">\n                  <riv-icon\n                    [size]=\"12\"\n                    [name]=\"\n                      s.query.order?.column === column.name &&\n                      s.query.order?.direction === 'desc'\n                        ? 'ArrowDown'\n                        : 'ArrowUp'\n                    \"\n                  ></riv-icon>\n                </span>\n              </button>\n              <table-header-resize-handle\n                (dragResize)=\"setWidth(column.name, $event)\"\n              ></table-header-resize-handle>\n            </th>\n            <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n          </tr>\n        </thead>\n        <tbody>\n          <ng-container *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\">\n            <ng-container\n              *ngFor=\"let row of s.result.rows; trackBy: trackByRow\"\n            >\n              <ng-template #rowBody>\n                <td *ngIf=\"selectionTemplate\" class=\"selection-body\">\n                  <div class=\"checkbox-wrapper\">\n                    <riv-checkbox\n                      [identifier]=\"'riv-table-selection-' + row.id\"\n                      [value]=\"row.selected\"\n                      (valueChange)=\"\n                        manager?.actions?.next({\n                          type: 'rowSelectedChange',\n                          id: row.id,\n                          selected: $event\n                        })\n                      \"\n                    ></riv-checkbox>\n                  </div>\n                </td>\n                <td\n                  *ngFor=\"let column of s.display.columns\"\n                  [class.pinned]=\"column.pinned\"\n                  [class.advanced]=\"column.dataType === 'advanced'\"\n                  [style.left.px]=\"column.left\"\n                  [style.text-align]=\"column.alignment\"\n                  (click)=\"\n                    column.dataType === 'advanced'\n                      ? $event.preventDefault()\n                      : null\n                  \"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"\n                      cellTemplate || null;\n                      context: { row: row, column: column }\n                    \"\n                  ></ng-container>\n                </td>\n                <td\n                  *ngIf=\"menuTemplate\"\n                  class=\"menu-body\"\n                  (click)=\"$event.preventDefault()\"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"\n                      menuTemplate || null;\n                      context: { row: row }\n                    \"\n                  ></ng-container>\n                </td>\n              </ng-template>\n              <a *ngIf=\"row.rowLink; let href\" [href]=\"href\" class=\"row-link\">\n                <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n              </a>\n              <tr *ngIf=\"!row.rowLink\">\n                <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n              </tr>\n            </ng-container>\n          </ng-container>\n          <ng-template #empty>\n            <tr>\n              <td [attr.colspan]=\"s.display.columns.length\">\n                <riv-zero-state\n                  *ngIf=\"s.display.zeroStateMessage; let message\"\n                  [message]=\"message\"\n                ></riv-zero-state>\n              </td>\n            </tr>\n          </ng-template>\n        </tbody>\n      </table>\n    </div>\n    <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination\">\n      <div class=\"page-size-controls\">\n        Results per page:\n        <riv-single-select\n          [selectedOption]=\"{\n            id: s.query.pagination.pageSize.toString(),\n            title: s.query.pagination.pageSize.toString(),\n            value: s.query.pagination.pageSize\n          }\"\n          (selectedOptionChange)=\"\n            manager?.actions?.next({\n              type: 'pageSizeChange',\n              size: $event.value\n            })\n          \"\n          [groups]=\"pageSizeOptions\"\n        ></riv-single-select>\n      </div>\n      <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination-controls\">\n        <button\n          class=\"paginate previous\"\n          type=\"button\"\n          [disabled]=\"s.query.pagination.previous === null\"\n          (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n        >\n          <riv-icon [name]=\"'ArrowLeft'\" [size]=\"16\"></riv-icon>\n        </button>\n        <span *ngIf=\"s.query.pagination.pages[0] > 0\" class=\"truncated-pages\">\n          &hellip;\n        </span>\n        <button\n          *ngFor=\"let page of s.query.pagination.pages\"\n          class=\"page\"\n          type=\"button\"\n          [disabled]=\"page === s.query.pagination.page\"\n          (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n        >\n          {{ page + 1 }}\n        </button>\n        <span\n          *ngIf=\"\n            s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n            s.query.pagination.pageCount - 1\n          \"\n          class=\"truncated-pages\"\n        >\n          &hellip;\n        </span>\n        <button\n          class=\"paginate next\"\n          type=\"button\"\n          [disabled]=\"s.query.pagination.next === null\"\n          (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n        >\n          <riv-icon [name]=\"'ArrowRight'\" [size]=\"16\"></riv-icon>\n        </button>\n      </div>\n    </div>\n  </riv-loading-cover>\n</ng-container>\n"]}
|