mirror of
https://github.com/immich-app/immich.git
synced 2025-11-21 15:30:41 +09:00
Some checks are pending
CodeQL / Analyze (javascript) (push) Waiting to run
CodeQL / Analyze (python) (push) Waiting to run
Docker / pre-job (push) Waiting to run
Docker / Re-Tag ML () (push) Blocked by required conditions
Docker / Re-Tag ML (-armnn) (push) Blocked by required conditions
Docker / Re-Tag ML (-cuda) (push) Blocked by required conditions
Docker / Re-Tag ML (-openvino) (push) Blocked by required conditions
Docker / Re-Tag ML (-rknn) (push) Blocked by required conditions
Docker / Re-Tag ML (-rocm) (push) Blocked by required conditions
Docker / Re-Tag Server () (push) Blocked by required conditions
Docker / Build and Push ML (armnn, linux/arm64, -armnn) (push) Blocked by required conditions
Docker / Build and Push ML (cpu, ) (push) Blocked by required conditions
Docker / Build and Push ML (cuda, linux/amd64, -cuda) (push) Blocked by required conditions
Docker / Build and Push ML (openvino, linux/amd64, -openvino) (push) Blocked by required conditions
Docker / Build and Push ML (rknn, linux/arm64, -rknn) (push) Blocked by required conditions
Docker / Build and Push ML (rocm, linux/amd64, {"linux/amd64": "mich"}, -rocm) (push) Blocked by required conditions
Docker / Build and Push Server (push) Blocked by required conditions
Docker / Docker Build & Push Server Success (push) Blocked by required conditions
Docker / Docker Build & Push ML Success (push) Blocked by required conditions
Docs build / pre-job (push) Waiting to run
Docs build / Docs Build (push) Blocked by required conditions
Static Code Analysis / pre-job (push) Waiting to run
Static Code Analysis / Run Dart Code Analysis (push) Blocked by required conditions
Static Code Analysis / zizmor (push) Waiting to run
Test / pre-job (push) Waiting to run
Test / Test & Lint Server (push) Blocked by required conditions
Test / Unit Test CLI (push) Blocked by required conditions
Test / Unit Test CLI (Windows) (push) Blocked by required conditions
Test / Lint Web (push) Blocked by required conditions
Test / Test Web (push) Blocked by required conditions
Test / Test i18n (push) Blocked by required conditions
Test / End-to-End Lint (push) Blocked by required conditions
Test / Medium Tests (Server) (push) Blocked by required conditions
Test / End-to-End Tests (Server & CLI) (ubuntu-24.04-arm) (push) Blocked by required conditions
Test / End-to-End Tests (Server & CLI) (ubuntu-latest) (push) Blocked by required conditions
Test / End-to-End Tests (Web) (ubuntu-24.04-arm) (push) Blocked by required conditions
Test / End-to-End Tests (Web) (ubuntu-latest) (push) Blocked by required conditions
Test / End-to-End Tests Success (push) Blocked by required conditions
Test / Unit Test Mobile (push) Blocked by required conditions
Test / Unit Test ML (push) Blocked by required conditions
Test / .github Files Formatting (push) Blocked by required conditions
Test / ShellCheck (push) Waiting to run
Test / OpenAPI Clients (push) Waiting to run
Test / SQL Schema Checks (push) Waiting to run
154 lines
4.4 KiB
Dart
154 lines
4.4 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter/rendering.dart';
|
|
|
|
class FixedTimelineRow extends MultiChildRenderObjectWidget {
|
|
final double dimension;
|
|
final double spacing;
|
|
final TextDirection textDirection;
|
|
|
|
const FixedTimelineRow({
|
|
super.key,
|
|
required this.dimension,
|
|
required this.spacing,
|
|
required this.textDirection,
|
|
required super.children,
|
|
});
|
|
|
|
@override
|
|
RenderObject createRenderObject(BuildContext context) {
|
|
return RenderFixedRow(
|
|
dimension: dimension,
|
|
spacing: spacing,
|
|
textDirection: textDirection,
|
|
);
|
|
}
|
|
|
|
@override
|
|
void updateRenderObject(BuildContext context, RenderFixedRow renderObject) {
|
|
renderObject.dimension = dimension;
|
|
renderObject.spacing = spacing;
|
|
renderObject.textDirection = textDirection;
|
|
}
|
|
|
|
@override
|
|
void debugFillProperties(DiagnosticPropertiesBuilder properties) {
|
|
super.debugFillProperties(properties);
|
|
properties.add(DoubleProperty('dimension', dimension));
|
|
properties.add(DoubleProperty('spacing', spacing));
|
|
properties.add(EnumProperty<TextDirection>('textDirection', textDirection));
|
|
}
|
|
}
|
|
|
|
class _RowParentData extends ContainerBoxParentData<RenderBox> {}
|
|
|
|
class RenderFixedRow extends RenderBox
|
|
with
|
|
ContainerRenderObjectMixin<RenderBox, _RowParentData>,
|
|
RenderBoxContainerDefaultsMixin<RenderBox, _RowParentData> {
|
|
RenderFixedRow({
|
|
List<RenderBox>? children,
|
|
required double dimension,
|
|
required double spacing,
|
|
required TextDirection textDirection,
|
|
}) : _dimension = dimension,
|
|
_spacing = spacing,
|
|
_textDirection = textDirection {
|
|
addAll(children);
|
|
}
|
|
|
|
double get dimension => _dimension;
|
|
double _dimension;
|
|
|
|
set dimension(double value) {
|
|
if (_dimension == value) return;
|
|
_dimension = value;
|
|
markNeedsLayout();
|
|
}
|
|
|
|
double get spacing => _spacing;
|
|
double _spacing;
|
|
|
|
set spacing(double value) {
|
|
if (_spacing == value) return;
|
|
_spacing = value;
|
|
markNeedsLayout();
|
|
}
|
|
|
|
TextDirection get textDirection => _textDirection;
|
|
TextDirection _textDirection;
|
|
|
|
set textDirection(TextDirection value) {
|
|
if (_textDirection == value) return;
|
|
_textDirection = value;
|
|
markNeedsLayout();
|
|
}
|
|
|
|
@override
|
|
void setupParentData(RenderBox child) {
|
|
if (child.parentData is! _RowParentData) {
|
|
child.parentData = _RowParentData();
|
|
}
|
|
}
|
|
|
|
double get intrinsicWidth => dimension * childCount + spacing * (childCount - 1);
|
|
|
|
@override
|
|
double computeMinIntrinsicWidth(double height) => intrinsicWidth;
|
|
|
|
@override
|
|
double computeMaxIntrinsicWidth(double height) => intrinsicWidth;
|
|
|
|
@override
|
|
double computeMinIntrinsicHeight(double width) => dimension;
|
|
|
|
@override
|
|
double computeMaxIntrinsicHeight(double width) => dimension;
|
|
|
|
@override
|
|
double? computeDistanceToActualBaseline(TextBaseline baseline) {
|
|
return defaultComputeDistanceToHighestActualBaseline(baseline);
|
|
}
|
|
|
|
@override
|
|
bool hitTestChildren(BoxHitTestResult result, {required Offset position}) {
|
|
return defaultHitTestChildren(result, position: position);
|
|
}
|
|
|
|
@override
|
|
void paint(PaintingContext context, Offset offset) {
|
|
defaultPaint(context, offset);
|
|
}
|
|
|
|
@override
|
|
void debugFillProperties(DiagnosticPropertiesBuilder properties) {
|
|
super.debugFillProperties(properties);
|
|
properties.add(DoubleProperty('dimension', dimension));
|
|
properties.add(DoubleProperty('spacing', spacing));
|
|
properties.add(EnumProperty<TextDirection>('textDirection', textDirection));
|
|
}
|
|
|
|
@override
|
|
void performLayout() {
|
|
RenderBox? child = firstChild;
|
|
if (child == null) {
|
|
size = constraints.smallest;
|
|
return;
|
|
}
|
|
// Use the entire width of the parent for the row.
|
|
size = Size(constraints.maxWidth, dimension);
|
|
// Each tile is forced to be dimension x dimension.
|
|
final childConstraints = BoxConstraints.tight(Size(dimension, dimension));
|
|
final flipMainAxis = textDirection == TextDirection.rtl;
|
|
Offset offset = Offset(flipMainAxis ? size.width - dimension : 0, 0);
|
|
final dx = (flipMainAxis ? -1 : 1) * (dimension + spacing);
|
|
// Layout each child horizontally.
|
|
while (child != null) {
|
|
child.layout(childConstraints, parentUsesSize: false);
|
|
final childParentData = child.parentData! as _RowParentData;
|
|
childParentData.offset = offset;
|
|
offset += Offset(dx, 0);
|
|
child = childParentData.nextSibling;
|
|
}
|
|
}
|
|
}
|