-
Notifications
You must be signed in to change notification settings - Fork 18
Adds Misc helper for file information and formatting #474
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Changes from 8 commits
593207c
162ed8d
8e551c2
829a702
3c22de9
c82223e
bb88906
956c556
c949b46
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,124 @@ | ||
| <?php | ||
|
|
||
| namespace BEA\Theme\Framework\Helpers\Misc; | ||
|
|
||
| /** | ||
| * Get file infos | ||
| * | ||
| * @param int $file_id | ||
| * | ||
| * @return array $file_infos | ||
| */ | ||
| function get_file_infos( int $file_id ): array { | ||
| $file_href = wp_get_attachment_url( $file_id ); | ||
| $file_infos = [ | ||
| 'href' => '', | ||
| 'file_name' => '', | ||
| 'path' => '', | ||
| 'size' => '', | ||
| 'ext' => '', | ||
| 'caption' => '', | ||
| ]; | ||
|
|
||
| if ( empty( $file_href ) ) { | ||
sourcery-ai[bot] marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| return $file_infos; | ||
| } | ||
|
|
||
| $file_path = get_attached_file( $file_id ); | ||
|
|
||
| if ( empty( $file_path ) ) { | ||
| return $file_infos; | ||
| } | ||
|
|
||
| $file_ext = pathinfo( $file_path, PATHINFO_EXTENSION ); | ||
|
|
||
| if ( empty( $file_ext ) ) { | ||
| return $file_infos; | ||
| } | ||
|
|
||
| $file_size = (string) size_format( wp_filesize( $file_path ) ); | ||
| $file_name = (string) ( get_the_title( $file_id ) ?? '' ); | ||
|
|
||
| return [ | ||
| 'file_name' => $file_name, | ||
| 'details' => get_file_detail( $file_name, $file_ext, $file_size ), | ||
| 'details_accessible' => get_file_detail( $file_name, $file_ext, get_accessible_file_size_label( $file_size ) ), | ||
| 'href' => $file_href, | ||
| 'caption' => (string) wp_get_attachment_caption( $file_id ), | ||
| 'icon' => get_file_icon( $file_ext ), | ||
| ]; | ||
| } | ||
|
|
||
| /** | ||
| * Get file details | ||
| * | ||
| * @param string $file_name | ||
| * @param string $file_ext | ||
| * @param string $file_size | ||
| * | ||
| * @return string $file_detail | ||
| */ | ||
| function get_file_detail( string $file_name, string $file_ext, string $file_size ): string { | ||
| $details = []; | ||
|
|
||
| if ( ! empty( $file_name ) ) { | ||
| $details[] = $file_name; | ||
| } | ||
|
|
||
| if ( ! empty( $file_ext ) ) { | ||
| $details[] = strtoupper( $file_ext ); | ||
| } | ||
|
|
||
| if ( ! empty( $file_size ) ) { | ||
| $details[] = $file_size; | ||
| } | ||
|
|
||
| return implode( ' – ', $details ); | ||
| } | ||
|
|
||
| /** | ||
| * Get accessible file size label | ||
| * | ||
| * @param string $file_size | ||
| * | ||
| * @return string | ||
| */ | ||
| function get_accessible_file_size_label( string $file_size ): string { | ||
| // Extract value and unit from file size (e.g., "7ko" → "7" + "ko"). | ||
| preg_match( '/^([\d.,]+)\s*([a-zA-Z]+)$/', $file_size, $matches ); | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Regex fails on non-breaking space thousands separatorMedium Severity In French WordPress locale, Reviewed by Cursor Bugbot for commit c949b46. Configure here. |
||
| $value = $matches[1] ?? ''; | ||
| $int_value = (int) $value; // Cast to int for _n() pluralization. | ||
cedric07 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| $unit = strtolower( $matches[2] ?? '' ); | ||
|
|
||
| /* translators: file size units (byte, kilobyte, megabyte, etc.) */ | ||
| $unit_label = match ( $unit ) { | ||
| 'b', 'o' => _n( 'byte', 'bytes', $int_value, 'beapi-frontend-framework' ), | ||
| 'kb', 'ko' => _n( 'kilobyte', 'kilobytes', $int_value, 'beapi-frontend-framework' ), | ||
| 'mb', 'mo' => _n( 'megabyte', 'megabytes', $int_value, 'beapi-frontend-framework' ), | ||
| 'gb', 'go' => _n( 'gigabyte', 'gigabytes', $int_value, 'beapi-frontend-framework' ), | ||
| 'tb', 'to' => _n( 'terabyte', 'terabytes', $int_value, 'beapi-frontend-framework' ), | ||
| default => null, | ||
| }; | ||
|
|
||
| if ( null === $unit_label ) { | ||
| return $file_size; | ||
| } | ||
|
|
||
| return $value . ' ' . $unit_label; | ||
| } | ||
|
|
||
| /** | ||
| * @param string $file_ext | ||
| * | ||
| * @return string | ||
| */ | ||
| function get_file_icon( string $file_ext ): string { | ||
|
|
||
| $file_icon = 'file'; | ||
|
|
||
| if ( in_array( $file_ext, [ 'jpg', 'jpeg', 'png', 'gif', 'webp', 'svg', 'bmp', 'ico' ], true ) ) { | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Case-sensitive extension check fails for uppercase extensionsMedium Severity The Reviewed by Cursor Bugbot for commit c949b46. Configure here. |
||
| $file_icon = 'file-image'; | ||
| } | ||
|
|
||
| return $file_icon; | ||
| } | ||


Uh oh!
There was an error while loading. Please reload this page.